《跟我学Shiro》笔记13-RememberMe
原文地址:第十三章 RememberMe——《跟我学Shiro》
目录贴: 跟我学Shiro目录贴
源码:https://github.com/zhangkaitao/shiro-example
Shiro 提供了记住我(RememberMe
)的功能,比如访问如淘宝等一些网站时,关闭了浏览器下次再打开时还是能记住你是谁,下次访问时无需再登录即可访问,基本流程如下:
- 首先在登录页面选中
RememberMe
然后登录成功;如果是浏览器登录,一般会把RememberMe
的Cookie
写到客户端并保存下来; - 关闭浏览器再重新打开;会发现浏览器还是记住你的;
- 访问一般的网页服务器端还是知道你是谁,且能正常访问;
- 但是比如我们访问淘宝时,如果要查看我的订单或进行支付时,此时还是需要再进行身份认证的,以确保当前用户还是你。
RememberMe 配置
spring-shiro-web.xml
配置:
<!-- 会话 Cookie 模板 -->
<bean id="sessionIdCookie" class="org.apache.shiro.web.servlet.SimpleCookie">
<constructor-arg value="sid"/>
<property name="httpOnly" value="true"/>
<property name="maxAge" value="-1"/> <!-- 表示浏览器关闭时失效此 Cookie -->
</bean>
<bean id="rememberMeCookie" class="org.apache.shiro.web.servlet.SimpleCookie">
<constructor-arg value="rememberMe"/>
<property name="httpOnly" value="true"/>
<property name="maxAge" value="2592000"/> <!-- 30 天 -->
</bean>
<!-- rememberMe 管理器 -->
<bean id="rememberMeManager" class="org.apache.shiro.web.mgt.CookieRememberMeManager">
<!-- rememberMe cookie 加密的密钥 建议每个项目都不一样 默认 AES 算法 密钥长度(128 256 512 位)-->
<property name="cipherKey"
value="#{T(org.apache.shiro.codec.Base64).decode('4AvVhmFLUs0KTA3Kprsdag==')}"/>
<property name="cookie" ref="rememberMeCookie"/>
</bean>
</bean>
<!-- 安全管理器 -->
<bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">
<property name="realm" ref="userRealm"/>
<property name="sessionManager" ref="sessionManager"/>
<property name="cacheManager" ref="cacheManager"/>
<!-- 设置 securityManager 安全管理器的 rememberMeManager -->
<property name="rememberMeManager" ref="rememberMeManager"/>
</bean>
<!-- 基于 Form 表单的身份验证过滤器 -->
<bean id="formAuthenticationFilter" class="org.apache.shiro.web.filter.authc.FormAuthenticationFilter">
<property name="usernameParam" value="username"/>
<property name="passwordParam" value="password"/>
<!-- rememberMeParam,即 rememberMe 请求参数名,请求参数是 boolean 类型,true 表示 rememberMe。
页面上可以 <input type="checkbox" name="rememberMe" value="true"> -->
<property name="rememberMeParam" value="rememberMe"/>
<property name="loginUrl" value="/login.jsp"/>
</bean>
<!-- Shiro 的 Web 过滤器 -->
<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">
<property name="securityManager" ref="securityManager"/>
<property name="loginUrl" value="/login.jsp"/>
<property name="unauthorizedUrl" value="/unauthorized.jsp"/>
<property name="filters">
<util:map>
<entry key="authc" value-ref="formAuthenticationFilter"/>
</util:map>
</property>
<!-- "/authenticated.jsp = authc" 表示访问该地址用户必须身份验证通过(Subject. isAuthenticated()==true);
而 "/** = user" 表示访问该地址的用户是身份验证通过或 RememberMe 登录的都可以。 -->
<property name="filterChainDefinitions">
<value>
/login.jsp = authc
/logout = logout
/authenticated.jsp = authc
/** = user
</value>
</property>
</bean>
自己做 RememeberMe
,需要在登录之前这样创建 Token
:UsernamePasswordToken
(用户名,密码,是否记住我),如:
Subject subject = SecurityUtils.getSubject();
UsernamePasswordToken token = new UsernamePasswordToken(username, password);
token.setRememberMe(true);
subject.login(token);
subject.isAuthenticated()
表示用户进行了身份验证登录的,即使有Subject.login
进行了登录;subject.isRemembered()
:表示用户是通过记住我登录的,此时可能并不是真正的你(如你的朋友使用你的电脑,或者你的cookie
被窃取)在访问的;- 且两者二选一,即
subject.isAuthenticated()==true
,则subject.isRemembered()==false
;反之一样。
另外对于过滤器,一般这样使用:
访问一般网页,如个人在主页之类的,我们使用 user
拦截器即可,user
拦截器只要用户登录 (isRemembered()==true or isAuthenticated()==true)
过即可访问成功;
访问特殊网页,如我的订单,提交订单页面,我们使用 authc
拦截器即可,authc
拦截器会判断用户是否是通过 Subject.login(isAuthenticated()==true)
登录的,如果是才放行,否则会跳转到登录页面叫你重新登录。
因此 RememberMe
使用过程中,需要配合相应的拦截器来实现相应的功能,用错了拦截器可能就不能满足你的需求了。
转载请注明来源,欢迎对文章中的引用来源进行考证,欢迎指出任何有错误或不够清晰的表达。可以在下面评论区评论,也可以邮件至 bin07280@qq.com
文章标题:《跟我学Shiro》笔记13-RememberMe
文章字数:1.1k
本文作者:Bin
发布时间:2018-04-19, 10:12:22
最后更新:2019-09-02, 17:51:36
原始链接:http://coolview.github.io/2018/04/19/%E8%B7%9F%E6%88%91%E5%AD%A6Shiro/%E3%80%8A%E8%B7%9F%E6%88%91%E5%AD%A6Shiro%E3%80%8B%E7%AC%94%E8%AE%B013-RememberMe/版权声明: "署名-非商用-相同方式共享 4.0" 转载请保留原文链接及作者。