解决filter登录验证死循环问题
2015-07-20 17:48
656 查看
Filter(过滤器)可以用它用来做登录验证,使没有登录的用户(即没有相关权限)无法访问某些功能,当用户访问这些功能的时候自动跳转到登陆界面。想法很美好,可是实际使用中常常遇到验证一直进行下去直到死循环的问题。
出现此问题的原因主要是当访问QueryFilterServlet时,因为用户没有登陆,所以将跳转到login.jsp,但是在Filter同样对login.jsp进行了过滤,所以当浏览器跳转到login.jsp时,经验证还是没有登录,那么会接着进行跳转,然后就报错了。
下面是解决该问题的三种思路:(推荐第二种方式)
一、将重定向改成请求转发
***这种方法的缺点是虽然跳转到了登陆界面,但地址栏显示的依然是QueryFilterServlet而不是login.jsp
2)当浏览器跳转到以login.jsp或FilterLoginServlet结尾时直接进行下一步,而不再进行过滤验证
filter中修改如下:
HttpServletRequest req= (HttpServletRequest) request;
***当浏览器跳转到以login.jsp或FilterLoginServlet结尾时表明是跳转到了登录界面(FilterLoginServlet是对登录信息验证的Servlet,所以此时没有必要再进行过滤)
3)修改web.xml文件
将要过滤的页面放在一个文件夹下然后配置filter的路径。或者将登录页面改成html静态页面,然后配置只过滤jsp页面即可。
此方法的缺点显而易见,要么增加页面数,要么无法返回适当的登录验证错误信息。
出现此问题的原因主要是当访问QueryFilterServlet时,因为用户没有登陆,所以将跳转到login.jsp,但是在Filter同样对login.jsp进行了过滤,所以当浏览器跳转到login.jsp时,经验证还是没有登录,那么会接着进行跳转,然后就报错了。
下面是解决该问题的三种思路:(推荐第二种方式)
一、将重定向改成请求转发
***这种方法的缺点是虽然跳转到了登陆界面,但地址栏显示的依然是QueryFilterServlet而不是login.jsp
2)当浏览器跳转到以login.jsp或FilterLoginServlet结尾时直接进行下一步,而不再进行过滤验证
filter中修改如下:
HttpServletRequest req= (HttpServletRequest) request;
***当浏览器跳转到以login.jsp或FilterLoginServlet结尾时表明是跳转到了登录界面(FilterLoginServlet是对登录信息验证的Servlet,所以此时没有必要再进行过滤)
3)修改web.xml文件
将要过滤的页面放在一个文件夹下然后配置filter的路径。或者将登录页面改成html静态页面,然后配置只过滤jsp页面即可。
此方法的缺点显而易见,要么增加页面数,要么无法返回适当的登录验证错误信息。
相关文章推荐
- JSP/PHP基于Ajax的分页功能实现
- jQuery plugin items filter
- 开发阶段Jetty运行Jsp报错且响应空白
- 全国哀悼日网站页面变成灰色的filter方法
- 用css filter做鼠标滑过图片效果
- Apache Web让JSP“动”起来
- ASP 使用Filter函数来检索数组的实现代码
- ASP.NET MVC:Filter和Action的执行介绍
- JSP 多条SQL语句同时执行的方法
- 在jsp页面中响应速度提高的7种方法分享
- (jsp/html)网页上嵌入播放器(常用播放器代码整理)
- JSP避免Form重复提交的三种方案
- jsp 标准标签库简析
- jsp 常用标签的使用
- JSP小知识简单介绍
- jsp页面中的代码执行加载顺序介绍
- jsp遍历文件夹下的文件的代码
- jsp fckeditor 上传中文图片乱码问题的解决方法