java中使用全局过滤器防止过滤css和js

我们使用过滤器验证用户是否登录时一般是不会过滤登录和注册界面的,所以要在过滤器中加一些判断条件来防止过滤这两个界面。但是使用全局过滤器的话会将这两个界面的css和js样式一起过滤掉,所以要在判断条件里加多几个条件。总之只要你不需要过滤掉的界面或控制器都可以在判断条件里加,示例如下


web.xml中的全局过滤器配置:

<!-- 验证是否登录的过滤器 -->
  <filter>
    <filter-name>SecurityFilter</filter-name>
    <filter-class>hua.sms.web.filter.SecurityFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>SecurityFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

过滤器中的过滤条件:

//不过滤登录注册界面
 if (session.getAttribute("userName") != null || req.getServletPath().indexOf("login.jsp") > 0 
 || req.getServletPath().indexOf("register.jsp") > 0 || req.getServletPath().endsWith(".css") || req.getServletPath().endsWith(".js") || req.getServletPath ().contains(".do")) {		
	//已登录			
	chain.doFilter(request, response);	//传给下个filter处理	
 } 
 else {//未登录
	res.sendRedirect("/sms/login.jsp");//跳转到登录网页,至此中断了过滤链
 }

这样就不会过滤掉登录和注册界面了,注意最好用endsWith()来防止过滤css和js样式,用contains的话只要包含这些样式的页面都会被防止过滤。

req.getServletPath().contains(".do")  这句是因为我不需要过滤掉SecurityServlet.do这个控制器的跳转。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值