当前位置:   article > 正文

java过滤器Filter_isfilter java

isfilter java

一、简介

Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序,主要的用途是过滤字符编码、做一些业务逻辑判断如是否有权限访问页面等。其工作原理是,只要你在web.xml文件配置好要拦截的客户端请求,它都会帮你拦截到请求,此时你就可以对请求或响应 (Request、Response)统一设置编码,简化操作;同时还可进行逻辑判断,如用户是否已经登陆、有没有权限访问该页面等等工作。它是随你的 web应用启动而启动的,只初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才销毁,以下通过代码示例来了解它 的使用。

二、实例

  1. package test.filter;
  2. import ...;
  3. /**
  4. * 介绍过滤器的使用,以设置编码为例
  5. */
  6. public class MyFilter implements Filter {
  7. private FilterConfig config = null;
  8. private boolean isFilter = false;
  9. public void destroy() {
  10. System.out.println("MyFilter准备销毁...");
  11. }
  12. public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain chain) throws IOException, ServletException {
  13. // 强制类型转换
  14. HttpServletRequest request = (HttpServletRequest)arg0;
  15. HttpServletResponse response = (HttpServletResponse)arg1;
  16. // 获取web.xm设置的编码集,设置到Request、Response 中
  17. request.setCharacterEncoding(config.getInitParameter("charset"));
  18. response.setContentType(config.getInitParameter("contentType"));
  19. response.setCharacterEncoding(config.getInitParameter("charset"));
  20. // 将请求转发到目的地继续执行
  21. chain.doFilter(request, response);
  22. }
  23. public void init(FilterConfig arg0) throws ServletException {
  24. this.config = arg0;
  25. if(isFilter){
  26. System.out.println("MyFilter初始化...");
  27. }
  28. }
  29. private void setIsFilter(boolean isFilter){
  30. this.isFilter = isFilter;
  31. }
  32. }

然后在web. xml中配置该过滤器:

  1. <filter>
  2. <filter-name>MyFilter</filter-name>
  3. <filter-class>test.filter.MyFilter</filter-class>
  4. <init-param>
  5. <param-name>isFilter</param-name>
  6. <param-value>true</param-value>
  7. </init-param>
  8. </filter>
  9. <filter-mapping>
  10. <filter-name>MyFilter</filter-name>
  11. <url-pattern>/*</url-pattern>
  12. <dispatcher>REQUEST</dispatcher> <!-- 没有配置dispatcher就是默认request方式的 -->
  13. <dispatcher>FORWARD</dispatcher>
  14. <dispatcher>ERROR</dispatcher>
  15. <dispatcher>INCLUDE</dispatcher>
  16. </filt

三、详细介绍

在doFilter方法中通常都做些什么呢,下面列举一下:

1、通过控制对chain.doFilter的方法的调用,来决定是否需要访问目标资源。

比如,可以在用户权限验证等等。判断用户是否有访问某些资源的权限,有权限放行,没权限不执行chain.doFilter方法。
2、在调用chain.doFilter方法之前,做些处理来达到某些目的。
比如,解决中文乱码的问题等等。可以在doFilter方法前,执行设置请求编码与响应的编码。甚至可以对request接口进行封装装饰来处理get请求方式的中文乱码问题(重写相应的request.getParameter方法)。
3、在调用chain.doFilter方法之后,做些处理来达到某些目的。
比如对整个web网站进行压缩。在调用chain.doFilter方法之前用类A对response对象进行封装装饰,重写getOutputStream和重写getWriter方法。在类A内部中,将输出内容缓存进ByteArrayOutputStream流中,然后在chain.doFilter方法执行后,获取类A中ByteArrayOutputStream流缓存数据,用GZIPOutputStream流进行压缩下。

Filter不仅可以通过url-pattern来指定拦截哪些url匹配的资源。而且还可以通过servlet-name来指定拦截哪个指定的servlet(专门为某个servlet服务了,servlet-name对应Servlet的相关配置)。

filter-mapping标签中dispatcher指定过滤器所拦截的资源被Servlet 容器调用的方式,可以是REQUEST,INCLUDE,FORWARD和ERROR之一,默认REQUEST。用户可以设置多个<dispatcher> 子元素用来指定 Filter 对资源的多种调用方式进行拦截。

REQUEST:

当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问或ERROR情况时,那么该过滤器就不会被调用。

INCLUDE:

如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。

FORWARD:

如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用,除此之外,该过滤器不会被调用。

ERROR:

如若在A.jsp页面page指令中指定了error属性=examError.jsp,那么A.jsp中若出现了异常,会跳转到examError.jsp中处理。而在跳转到examError.jsp时,若过滤器配置了ERROR的dispather那么则会拦截,否则不会拦截。

四、高级配置(允许代理注入spring bean)

web.xml中配置过滤器DelegatingFilterProxy:

 

  1. <filter>
  2. <filter-name>permission</filter-name>
  3. <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
  4. <init-param>
  5. <param-name>targetFilterLifecycle</param-name>
  6. <param-value>true</param-value>
  7. </init-param>
  8. </filter>
  9. <filter-mapping>
  10. <filter-name>permission</filter-name>
  11. <url-pattern>*.htm</url-pattern>
  12. </filter-mapping>

在spring bean配置中加入:

<bean id="permission" class="你的bean"></bean>

bean的id必须和filter-name一样。如果想不一样,可以这样配置:

  1. <filter>
  2. <filter-name>permission</filter-name>
  3. <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
  4. <init-param>
  5. <param-name>targetFilterLifecycle</param-name>
  6. <param-value>true</param-value>
  7. </init-param>
  8. <init-param>
  9. <param-name>targetBeanName</param-name>
  10. <param-value>test</param-value>
  11. </init-param>
  12. </filter>
  13. <filter-mapping>
  14. <filter-name>permission</filter-name>
  15. <url-pattern>*.htm</url-pattern>
  16. </filter-mapping>

在spring bean配置中加入:

<bean id="test" class="你的bean"></bean>

以上你的spring bean必须实现Filter接口。

那这样子做是为了什么呢?

答:这样做就可以将DelegatingFilterProxy所代理的filter作为spring的bean,受到spring的管理,也就是通过Spring容器来管理filter的生命周期,还有就是如果filter中需要一些Spring容器的实例,可以通过spring直接注入,另外读取一些配置文件这些便利的操作都可以通过Spring来配置实现。

其中如果设置"targetFilterLifecycle"为True,则Filter.init()和Filter.destroy()有效;若为false,则这两个方法失效。

如果大家有用到shiro(一个强大且易用的Java安全框架,执行身份验证、授权、密码学和会话管理等)的话,通常就会用到这个DelegatingFilterProxy了!

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/415043
推荐阅读
相关标签
  

闽ICP备14008679号