java filter 过滤器总结

过滤器总结
一、Servlet过滤器的概念:

Servlet过滤器是在Java Servlet规范2.3中定义的,它能够对Servlet容器的请求和响应对象进行检查和修改。   

Servlet过滤器本身并不产生请求和响应对象,它只能提供过滤作用。Servlet过期能够在Servlet被调用之前检查Request对象,修改Request Header和Request内容;在Servlet被调用之后检查Response对象,修改Response Header和Response内容。

Servlet过期负责过滤的Web组件可以是Servlet、JSP或者HTML文件。 

 

二、Servlet过滤器的特点:

A.Servlet过滤器可以检查和修改ServletRequest和ServletResponse对象
B.Servlet过滤器可以被指定和特定的URL关联,只有当客户请求访问该URL时,才会触发过滤器
C.Servlet过滤器可以被串联在一起,形成管道效应,协同修改请求和响应对象

 

三、Servlet过滤器的作用:

A.查询请求并作出相应的行动。
B.阻塞请求-响应对,使其不能进一步传递。
C.修改请求的头部和数据。用户可以提供自定义的请求。
D.修改响应的头部和数据。用户可以通过提供定制的响应版本实现。
E.与外部资源进行交互。

 

四、Servlet过滤器的适用场合:

A.认证过滤
B.登录和审核过滤
C.图像转换过滤
D.数据压缩过滤
E.加密过滤
F.令牌过滤
G.资源访问触发事件过滤
H.XSL/T过滤
I.Mime-type过滤

 

五、Servlet过滤器接口的构成:

所有的Servlet过滤器类都必须实现javax.servlet.Filter接口。这个接口含有3个过滤器类必须实现的方法:

A.init(FilterConfig):
这是Servlet过滤器的初始化方法,Servlet容器创建Servlet过滤器实例后将调用这个方法。在这个方法中可以读取web.xml文件中Servlet过滤器的初始化参数

B.doFilter(ServletRequest,ServletResponse,FilterChain):
这个方法完成实际的过滤操作,当客户请求访问于过滤器关联的URL时,Servlet容器将先调用过滤器的doFilter方法。FilterChain参数用于访问后续过滤器

B.destroy():
Servlet容器在销毁过滤器实例前调用该方法,这个方法中可以释放Servlet过滤器占用的资源

 

六、Servlet过滤器的创建步骤:

A.实现javax.servlet.Filter接口
B.实现init方法,读取过滤器的初始化函数
C.实现doFilter方法,完成对请求或过滤的响应
D.调用FilterChain接口对象的doFilter方法,向后续的过滤器传递请求或响应
E.销毁过滤器

 

七、Servlet过滤器对请求的过滤:

A.Servlet容器创建一个过滤器实例
B.过滤器实例调用init方法,读取过滤器的初始化参数
C.过滤器实例调用doFilter方法,根据初始化参数的值判断该请求是否合法
D.如果该请求不合法则阻塞该请求
E.如果该请求合法则调用chain.doFilter方法将该请求向后续传递

 

八、Servlet过滤器对响应的过滤:

A.过滤器截获客户端的请求
B.重新封装ServletResponse,在封装后的ServletResponse中提供用户自定义的输出流
C.将请求向后续传递
D.Web组件产生响应
E.从封装后的ServletResponse中获取用户自定义的输出流
F.将响应内容通过用户自定义的输出流写入到缓冲流中
G.在缓冲流中修改响应的内容后清空缓冲流,输出响应内容


九、Servlet过滤器的发布:

A.发布Servlet过滤器时,必须在web.xml文件中加入<filter>元素和<filter-mapping>元素。

B.<filter>元素用来定义一个过滤器:
属性                   含义
filter-name    指定过滤器的名字
filter-class    指定过滤器的类名
init-param    为过滤器实例提供初始化参数,可以有多个

C.<filter-mapping>元素用于将过滤器和URL关联:
属性                     含义
filter-name    指定过滤器的名字
url-pattern    指定和过滤器关联的URL,为"/"表示所有URL

 

十一、Servlet过滤器使用的注意事项

A.由于Filter、FilterConfig、FilterChain都是位于javax.servlet包下,并非HTTP包所特有的,所以其中所用到的请求、响应对象ServletRequest、ServletResponse在使用前都必须先转换成HttpServletRequest、HttpServletResponse再进行下一步操作。

B.在web.xml中配置Servlet和Servlet过滤器,应该先声明过滤器元素,再声明Servlet元素


C.如果要在Servlet中观察过滤器生成的日志,应该确保在server.xml的localhost对应的<host>元素中配置如下<logger>元素:
<Logger className = "org.apache.catalina.logger.FileLogger"
directory = "logs" prefix = "localhost_log."suffix=".txt"
timestamp = "true"/>

常用的过滤器实例:

  1. <PRE class=java name="code">//对整站编码的过滤   
  2. public void doFilter(ServletRequest request, ServletResponse sresponse,FilterChain chain) {   
  3.   try{   
  4.    request.setCharacterEncoding("GBK");   
  5.    chain.doFilter(request, sresponse);   
  6.   }catch(Exception e){   
  7.    e.printStackTrace();   
  8.   }   
  9.  }   
  10. //对用户登陆进行验证    
  11.  public void doFilter(ServletRequest srequest, ServletResponse sresponse,FilterChain chain) {   
  12.   try {   
  13.    HttpServletRequest request = (HttpServletRequest) srequest;   
  14.    HttpServletResponse response = (HttpServletResponse) sresponse;   
  15.    HttpSession session = request.getSession();   
  16.    User user = (User) session.getAttribute("user");   
  17.    if (user == null) {    
  18.      response.sendRedirect("/test/index.html");    
  19.    } else {   
  20.     chain.doFilter(request, response);   
  21.    }   
  22.   } catch (Exception e) {   
  23.    e.printStackTrace();   
  24.   }   
  25.  }   
  26. //对用户权限进行过滤    
  27. public void doFilter(ServletRequest srequest, ServletResponse sresponse,FilterChain chain) {   
  28.   try {   
  29.    HttpServletRequest requst = (HttpServletRequest) srequest;   
  30.    HttpServletResponse response = (HttpServletResponse) sresponse;   
  31.    HttpSession session = requst.getSession();   
  32.    User user = (User) session.getAttribute("user");   
  33.    String ad=user.getIsAdmin().toString();   
  34.    if (user == null || ad.equals("0")) {    
  35.      response.sendRedirect("/test/main.jsp");   
  36.    } else {   
  37.     chain.doFilter(srequest, sresponse);   
  38.    }   
  39.   } catch (Exception e) {   
  40.    e.printStackTrace();   
  41.   }   
  42.  }    
  43. </PRE>  

  
  
  1. //对整站编码的过滤   
  2. public void doFilter(ServletRequest request, ServletResponse sresponse,FilterChain chain) {   
  3.   try{   
  4.    request.setCharacterEncoding("GBK");   
  5.    chain.doFilter(request, sresponse);   
  6.   }catch(Exception e){   
  7.    e.printStackTrace();   
  8.   }   
  9.  }   
  10. //对用户登陆进行验证    
  11.  public void doFilter(ServletRequest srequest, ServletResponse sresponse,FilterChain chain) {   
  12.   try {   
  13.    HttpServletRequest request = (HttpServletRequest) srequest;   
  14.    HttpServletResponse response = (HttpServletResponse) sresponse;   
  15.    HttpSession session = request.getSession();   
  16.    User user = (User) session.getAttribute("user");   
  17.    if (user == null) {    
  18.      response.sendRedirect("/test/index.html");    
  19.    } else {   
  20.     chain.doFilter(request, response);   
  21.    }   
  22.   } catch (Exception e) {   
  23.    e.printStackTrace();   
  24.   }   
  25.  }   
  26. //对用户权限进行过滤    
  27. public void doFilter(ServletRequest srequest, ServletResponse sresponse,FilterChain chain) {   
  28.   try {   
  29.    HttpServletRequest requst = (HttpServletRequest) srequest;   
  30.    HttpServletResponse response = (HttpServletResponse) sresponse;   
  31.    HttpSession session = requst.getSession();   
  32.    User user = (User) session.getAttribute("user");   
  33.    String ad=user.getIsAdmin().toString();   
  34.    if (user == null || ad.equals("0")) {    
  35.      response.sendRedirect("/test/main.jsp");   
  36.    } else {   
  37.     chain.doFilter(srequest, sresponse);   
  38.    }   
  39.   } catch (Exception e) {   
  40.    e.printStackTrace();   
  41.   }   
  42.  }   

web.xml中的配置

  1. <FILTER></FILTER>  
  2.     <FILTER-NAME></FILTER-NAME>encodingfilter   
  3.     <FILTER-CLASS></FILTER-CLASS>filter.EncodingFilter   
  4.      
  5.   <FILTER></FILTER>  
  6.   <FILTER-NAME></FILTER-NAME>firstfilter   
  7.   <FILTER-CLASS></FILTER-CLASS>filter.FirstFilter   
  8.      
  9.   <FILTER></FILTER>  
  10.   <FILTER-NAME></FILTER-NAME>secondfilter   
  11.   <FILTER-CLASS></FILTER-CLASS>filter.SecondFilter   
  12.      
  13.   <FILTER-MAPPING></FILTER-MAPPING>  
  14.     <FILTER-NAME></FILTER-NAME>encodingfilter   
  15.     <URL-PATTERN></URL-PATTERN>/*   
  16.      
  17.   <FILTER-MAPPING></FILTER-MAPPING>  
  18.     <FILTER-NAME></FILTER-NAME>firstfilter   
  19.     <URL-PATTERN></URL-PATTERN>/web/*   
  20.      
  21.     <FILTER-MAPPING></FILTER-MAPPING>  
  22.     <FILTER-NAME></FILTER-NAME>secondfilter   
  23.     <URL-PATTERN></URL-PATTERN>/web/Charge.jsp   
  24.      
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值