Spring-shiro-Boot-6 shiro中的自定义过滤器-RestfulFilter

使用shiro自定义RestfulFilter过滤器。

该过滤器主要功能:

(1)在参数中或者header里加参数login-token作为登陆凭证。

(2)通过token来管理登录的无状态。取代传统的session模式。

过滤器的基础知识可以查看我的上一篇博客。我们使用shiro的UserFilter作为父类完成rest功能。

实现自定义过滤器主要实现以下几个方法:

//通过时
(1)isAccessAllowed
//拒绝时
(2)onAccessDenied
//根据参数或者header获取login-token
(3)getToken
//针对rest请求,对响应做对应处理
(4)writeResponse

具体来说:

(1)如果判断到请求中包含token,从redis中根据loginToken获取UsernamePasswordToken,交给shiro进行验证。成功返回true。

(2)如果判断到请求中包含token,但没有通过验证。对响应进行包装

1、设置ServletResponse-->HttpServletResponse

2、设置HttpStatus-->401, "Unauthorized"

3、设置info-->json:401 token不存在或者过期

(3)如果请求中token为空,按照传统方式进行验证(过滤器不做)。

getToken如下

public static String getToken(ServletRequest request) {
		HttpServletRequest httpServletRequest = WebUtils.toHttp(request);
		//从参数中获取token
		String loginToken = httpServletRequest.getParameter(UserConstants.LOGIN_TOKEN);
		if (StringUtils.isBlank(loginToken)) {
		    //从header中获取token
			loginToken = httpServletRequest.getHeader(UserConstants.LOGIN_TOKEN);
		}
		return loginToken;
	}

在配置类ShiroConfig中设置自定义的过滤器

 // 6、加载自定义过滤器
shiroFilterFactoryBean.getFilters().put("authc", restfulFilter);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

良之才-小良

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值