您的位置:首页 > Web前端 > JavaScript

解决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页面即可。

此方法的缺点显而易见,要么增加页面数,要么无法返回适当的登录验证错误信息。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  jsp filter