时间:2021-05-19
最近在写一个购书网站,测试注销功能时点击浏览器返回刷新浏览器,会发现原本已经注销的用户又重新登录了
想了很久在网上也找了很多办法,不过网上给出的办法大多是用js实现注销后禁止用户点击游览器返回
这个办法虽然可行,但并不是在后台真正的解决这个问题,有一种防君子不防小人的感觉
下面把自己实现的方法记录下来
原理:
注销后点击浏览器返回刷新浏览器其实就是浏览器将原来form表单的信息重新发送了一遍
注销也就是干掉原来的session
当注销后重定向到一个jsp页面是生成session与原来的session是不同的(jsp页面session默认是开启的)
也就是说注销后点击浏览器返回刷新的session是新的session,从这个角度出发思考解决办法
我在原来的session里放一段数据,第一次登陆能获取到这段数据,注销后原来的session没了,点击浏览器返回刷新,新的session里没有放数据,获取的值就是null
将原来的session里的数据与新的session值进行匹配,一个有值,一个为null,肯定会匹配失败,这时可以给用户友好的提示,让用户重新登录即可。
那么原来session里的数据如何在注销后(注销了原来的session就没了)保存呢?考虑在表单里增加一个隐藏域,将原来的session里的数据放在该隐藏域中,这样注销后点击浏览器返回刷新,浏览器会自动把原来session里的数据提交一遍,无需自己手动保存(事实上手动保存可能得放在servletContext应用上下文中,没试过)
有点类似于解决表单重复提交的一种办法,但是这里不能把原来的session里数据干掉,因为注销前后不是同一个session
具体如下:在login.jsp里
在servlet中,给出友好提示并重定向到登录页面
测试:
登录
注销后点击浏览器返回刷新,浏览器会提示是否重新发送数据
点击重新发送
这样就解决了注销后点击浏览器返回刷新用户重新登录的问题。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
QQ浏览器APP设置小说模式步骤如下: 1、手机点击打开并登录【QQ浏览器APP】。 2、进入首页后,点击右下角【我的】。 3、跳转新页面后,点击右上角【
360浏览器点击提示请设置您浏览器允许弹窗的设置方法,这样就可以打开新页面了。方法/步骤1、打开360安全浏览器2、点击网页右上方【工具】选项3、点击【选项】选
无刷新页面再次操作form表单时,点击无效果重点来了!解决方法!需要form.render();代码如下:layui.use('form',function()
ajax可以实现局部刷新页面,即在不刷新整个页面的情况下更新页面的局部信息。项目中遇到一个问题:在用户列表也,当点击某个按钮时需要去查询用户的信息,查询成功跳转
如下所示:/***如果是直接输入url访问的则刷新页面(防止缓存页面)针对Chrome,其他浏览器刷新referrer始终会为空,所以给个随机路径访问就加载不到