过滤器会拦截 前端页面加载 js文件的请求

时间:2023-03-09 06:17:43
过滤器会拦截  前端页面加载 js文件的请求

学艺不精啊.....之前就总结过博客:

JAVA中解决Filter过滤掉css,js,图片文件等问题

结果现在又犯了老错误~

情况如下:

index.jsp 页面的验证码输入栏绑定了异步验证(jQurey实现),当输入内容发生变化时,异步去后台验证输入是否正确。

 $(function(){

    $("#a").bind('input propertychange',function () {

       var registName=this.value;

       var param={"method":"checkRegistName","registName":registName};

       $.get("User.do",param,function(data){            

          if(data!="1"){

             $(this).parent().children("span").html("用户名可以使用");

          }else{

             $(this).parent().children("span").html("用户名已被占用");

          }

       }.bind(this))

       //ajax中的回调函数直接用this不灵,解决办法是使用bind(this)绑定this到当前事件。

    });

 }

但是当项目加入了登录验证(过滤器)后,发现这个验证失效了。

经过检查发现,过滤器会拦截 页面对  js文件的请求。

过滤器中加入如下代码:

 System.out.println( "登录验证过滤器  loginFilter" );

 String url = httpRequest.getServletPath();

 System.out.println("经过过滤器的请求url为 "+url);

访问页面,工作台输出如下:

 登录验证过滤器  loginFilter
经过过滤器的请求url为 /index.jsp
登录验证过滤器 loginFilter
经过过滤器的请求url为 /js/jquery.js
登录验证过滤器 loginFilter
经过过滤器的请求url为 /yanzheng

其中 “index.jsp” 为访问的页面, “/js/jquery.js”为index.jsp 中加载的js文件,“/yanzheng”是验证码图片获取时访问的后台severlet地址。

因此,前端 jQuery实现的ajax没有正常工作。

因此在过滤器中加入对  js 文件的判断,

 if("/index.jsp".equals(url) |"/yanzheng".equals(url)|"/js/jquery.js".equals(url)){         

         chain.doFilter(request, response);                

 }

~问题解决了