想想也不可能,网络中不会时不时出现cookie theft攻击吧。看了官方文档,也没给出解释,后来在oschina看到一篇分析的文章,才明白其中的缘由,文章《是谁动了我的cookie?Spring Security自动登录功能开发经历总结》。
从这篇文章的分析结合spring secutiy的源码来看,在每次持久化登录校验token完毕之后,会更新token的值并写入cookie。而token的校验是通过加密处理写入cookie中的字符串与持久化存储的token做对比看是否一致来判断登录信息。问题就出在这里,每次更新完token之后写入cookie的途中失败,导致cookie中token是旧值,而持久化存储的是新值。
那为什么会出现更新完token之后写入cookie的途中失败呢?那篇文章的作者分析的很到位,①多线程操作②服务端发生500异常③浏览器取消请求等等。
文章的作者建议不使用PersistentTokenBasedRememberMeServices,而改为使用TokenBasedRememberMeServices,TokenBasedRememberMeServices采用的是对用户名密码进行加密生成cookie的方式,token并未进行持久化存储。该方案被很多国内网站采用。
首先需要在applicationContext.xml文件中配置rememberMeServices:
代码如下 | 复制代码 |
当然这里的userDetailsService必须配置,它通常是实现了一个org.springframework.security.core.userdetails.UserDetailsService接口的java bean,你自己实现即可。
最后,在sec:http标签中配置sec:remember-me:
代码如下 | 复制代码 |
|
随后,重启你的应用,以后再也不用担心CookieTheftException了。
敢达决战官方正版 安卓版v6.7.9
下载敢达决战 安卓版v6.7.9
下载像素火影骨架佐助 (Perseverance Fire Shadow)手机版v1.16
下载要塞英雄 安卓版v33.20.0-39082670-Android
下载梦想城镇vivo最新版本 安卓版v12.0.1
梦想城镇vivo版是这款卡通风模拟经营类手游的渠道服版本,玩
怦然心动的瞬间 安卓版v1.0
怦然心动的瞬间是一款真人向的恋爱互动游戏,在游戏中玩家将扮演
曼尼汉堡店游戏 安卓版v1.0.3
曼尼汉堡店是一款非常好玩的精品恐怖类型冒险游戏,在这款游戏中
现代总统模拟器去广告版 安卓版v1.0.46
现代总统模拟器是一款休闲养成类游戏,可能对于不少的玩家来说都
现代总统模拟器付费完整版 安卓版v1.0.46
现代总统模拟器高级版在商店是需要付费的,相对于普通版本,高级