标签:request pat 除了 dex session attribute 一个 ssi on()
我在登出之后不但返回到刚才的页面。还因为我设置了拦截器而导致页面出现了我并不想看到的结果。
于是我着手对着问题进行了优化解决:
一开始我想这么做:在每张页面都有session判断,如果session为空则返回登录界面。但是就结果而言。出现了上面图片中的结果
后来我又想从前端页面着手,通过写js window.location.href返回登录界面。
这是代码:
<script type="text/javascript">
windows.location.href="/login/index"
</script>
在IE浏览器中完美解决。但我用火狐测试了一下。。。唉。?还是不得行?
我马上去检查了我的java代码
//获得session HttpSession session = req.getSession(); //拿到session里面的属性 Object attribute = session.getAttribute("USER_IN_SISSION"); //如果前台没有传信息,就跳转回登陆页面 if (attribute==null) { //跳转回登陆页面 req.getRequestDispatcher("/login/index").forward(req, resp); System.out.println("拦截器执行了"); return false; } return true;
@RequestMapping("/out") public String out(HttpServletRequest req) throws ServletException, IOException { // 获得session HttpSession session = req.getSession(); // 删除session里的内容 session.removeAttribute("USER_IN_SISSION"); return "redirect:/login/index"; }
上面这段代码完全没执行。
我又看了看xml配置
<mvc:interceptors> <mvc:interceptor> <!-- 不放行的 --> <mvc:mapping path="/**"/> <!-- 放行的 --> <mvc:exclude-mapping path="/login/*"/> <mvc:exclude-mapping path="/static/**"/> <mvc:exclude-mapping path="/index/*"/> <mvc:exclude-mapping path="/upload/*"/> <mvc:exclude-mapping path="/templates/*"/> <!-- 配置拦截器 --> <bean class="cn.king.web.Intercetor" /> </mvc:interceptor> </mvc:interceptors>
嗯。。。我自闭了。。。
我打了断点进debug调试。后台代码没什么问题。我想那就是前台页面了。我跟着去验了验拦截器对我没放行的路径是否进行了拦截。
结果,我发现了我这个项目的一个bug
因为我的主页面是这样写的:
解决在点击登出之后,用户点击浏览器回退按钮能返回去继续操作问题
标签:request pat 除了 dex session attribute 一个 ssi on()
原文地址:https://www.cnblogs.com/kingofjava/p/10420803.html