FilterLog代码分析

摘要:
Servlet API提供了一个Filter接口。在开发web应用程序时,如果您编写的Java类实现了此接口,则称为Filter。过滤器允许用户更改请求和修改响应过滤器不是servlet。它无法生成响应。它可以在请求到达servlet之前对其进行预处理,也可以在响应离开servlet时处理响应。2.实现Filter的三种方法:void init;用于完成过滤器的初始化。voiddestroy();它用于在过滤器被破坏之前回收一些资源。

1、Filter:Filter也称之为过滤器,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。Servlet API中提供了一个Filter接口,开发web应用时,如果编写的Java类实现了这个接口,则把这个java类称之为过滤器Filter。Filter使用户可以改变一个request和修改一个response. Filter 不是一个servlet,它不能产生一个response,它能够在一个request到达servlet之前预处理request,也可以在response离开servlet时处理response。

  2、实现Filter的3个方法:

  • void init(FilterConfig config);用于完成Filter的初始化。
  • void destroy();用于Filter销毁前,完成某些资源的回收。
  • void doFilter(ServletRequest request, ServletResponse response, FilterChain chain);实现过滤功能,对每个请求及响应增加的额外处理.

3.核心代码分析

  @WebFilter(filterName="log"
    ,urlPatterns={"/*"})//filterName指定该Filter的名称,urlPatterns指定该Filter所拦截的URL
  public class LogFilter implements Filter
  {
    //FilterConfig可用于访问Filter的配置信息
    private FilterConfig config;
    //实现初始化方法
    public void init(FilterConfig config)
    {
      this.config = config;
    }
    //实现销毁方法
    public void destroy()
    {  
    this.config = null;
    }
    //执行过滤的核心方法
    public void doFilter(ServletRequest request,
      ServletResponse response, FilterChain chain)//此方法的最后一个参数是FilterChain对象,此参数是用来调用servlet或JSP页。
      throws IOException,ServletException
     {
        //---------下面代码用于对用户请求执行预处理---------
        //获取ServletContext对象,用于记录日志
        ServletContext context = this.config.getServletContext();
        long before = System.currentTimeMillis();
        System.out.println("开始过滤...");
        //将请求转换成HttpServletRequest请求
        HttpServletRequest hrequest = (HttpServletRequest)request;
        //输出提示信息
        System.out.println("Filter已经截获到用户的请求的地址: " +
          hrequest.getServletPath());
        //Filter只是链式处理,请求依然放行到目的地址
        chain.doFilter(request, response);
        //---------下面代码用于对服务器响应执行后处理---------
        long after = System.currentTimeMillis();
        //输出提示信息
        System.out.println("过滤结束");
        //输出提示信息
        System.out.println("请求被定位到" + hrequest.getRequestURI() +
            " 所花的时间为: " + (after - before));
      }  
    }
其中重要的方法实现是通过ServletContext context = this.config.getServletContext();获取ServletContext对象,用于记录日志和将请求转换成HttpServletRequest请求HttpServletRequest hrequest = (HttpServletRequest)request;以及chain.doFilter(request, response);几个对象的使用来实现。
4.filter例子
1.编写java类实现Filter接口,并实现其doFilter方法

package com.bjpowernode.drp.util.filter;

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
mport javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;


public class CharseEncodingFilter implements Filter {
//成员变量,存放读取filter配置文件中的信息
private String endcoding;
//销毁方法
public void destroy() {}
//filter核心方法
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {

//设置字符集
//第一种方式直接填写字符编码的格式,这样不容易修改
request.setCharacterEncoding("GB18030");
response.setCharacterEncoding("GB18030");

//第二种方式读取filter配置文件中的信息这样便于维护和修改字符编码格式
request.setCharacterEncoding(endcoding);
response.setCharacterEncoding(endcoding);

//继续执行
chain.doFilter(request, response);
}
//filter初始化
public void init(FilterConfig arg0) throws ServletException {
this.endcoding =arg0.getInitParameter("encoding"); //读取filter配置文件中的信息
}

}


     FilterConfig接口:用户在配置filter时,可以使用<init-param>为filter配置一些初始化参数,当web容器实例化Filter对象,调用其init方法时,会把封装了filter初始化参数的filterConfig对象传递进来。在编写filter时,通过filterConfig对象的方法,就可获得   
     String getFilterName():得到filter的名称。     
     String getInitParameter(String name): 返回在部署描述中指定名称的初始化参数的值。如果不存在返回null.    
     Enumeration getInitParameterNames():返回过滤器的所有初始化参数的名字的枚举集合。    
     public ServletContext getServletContext():返回Servlet上下文对象的引用。

2.配置web.xml

<filter>    
         <filter-name>CharseEncodingFilter</filter-name>   <!--别名-->  
         <filter-class>com.bjpowernode.drp.util.filter.CharseEncodingFilter</filter-class>    <!--执行操作的类-->  
         <init-param>     <!--参数-->  
               <param-name>encoding</param-name>    <!--参数名-->  
               <param-value>GBK</param-value>     <!--参数值-->  
         </init-param>         
    </filter>  
      
    <filter-mapping>      <!--定义需要过滤的资源-->  
         <filter-name>CharseEncodingFilter</filter-name>   <!--别名与上面的相同-->  
         <url-pattern>/sysmgr/user_modify.jsp</url-pattern>    <!--具体的页面-->  
    </filter-mapping>

    Filter链:在一个web应用中,可以开发编写多个Filter,这些Filter组合起来称之为一个Filter链。

web服务器根据Filter在web.xml文件中的注册顺序,决定先调用哪个Filter,当第一个Filter的doFilter方法被调用时,web服务器会创建一个代表Filter链的FilterChain对象传递给该方法。在doFilter方法中,开发人员如果调用了FilterChain对象的doFilter方法,则web服务器会检查FilterChain对象中是否还有filter,如果有,则调用第2个filter,如果没有,则调用目标资源。一个对象可以配置多个filter,同时一个filter也可以对多个对象起作用。

四:总结

     filter的思想是面向切面编程,他提供了一种声明式服务,声明式服务非常强大,具有可拔插的能力,同时filter只是对post提交其作用。

 
 

免责声明:文章转载自《FilterLog代码分析》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇五、Abp vNext 基础篇丨博客聚合功能OpenCV学习(13) 细化算法(1)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

*引使用.ashx文件处理IHttpHandler实现发送文本及二进制数据的方法。

最近在做我们单位的内部一个系统,使用了类似于Asp.Net 2.0里面的Theme(主题)的功能。此功能的核心是一个动态的CSS定义,根据用户选择的不同主题内容来发送不同的CSS样式文本。 本来这个问题很好解决,在HTML中的<head>区内使用一个: <%#=base.GetCssInclude()%> 就可以解决,不过我没有...

bss段为什么需要初始化?

    我们都知道bss段需要初始化,但是这是为什么呢?        通过浏览资料,我们都会发现,bss段是不会出现在程序下载文件(*.bin *.hex)中的,因为全都是0。如果把它们出现在程序下载文件中,会增加程序下载文件的大小。实际应用中,通常只需要把bss段的起始地址和结束地址保存起来,而不需要将程序下载文件中出现bss段(一堆0)将来真正运行程...

Unity多语言本地化改进版

简介 之前捣鼓过一个通过csv配置游戏多语言支持的小工具,但是发现使用过程中,通过notepad++去进行转码很不方便,并且直接将配置的csv不加密的放在游戏中心里感觉不是很踏实 于是乎~~ 新的方案 1.在PC/MAC平台上解析多语言配置,也就是editor运行环境中解析csv或者excel 2.通过在Editor运行过程中生成多个语言对象,然后序列化并...

理解C# 4 dynamic(4) – 让人惊艳的Clay

理解C# 4 dynamic(4) – 让人惊艳的Clay Clay非常类似于ExpandoObject, 可以看做是ExpandoObject的加强版. 它们能够让我们在不需要定义类的情况下,就构建出我们想要的对象。Clay和ExpandoObject相比,提供了更加灵活的语法支持,让我们像写javascript代码一样写C#代码,同时还能够用于构建多层...

uboot完全手册---14

1. u-boot介绍 本次移植采用的是U-Boot-1.2.0版本。 3. U-Boot源码分析 3.1 源码入口的解释 可能大多数的同学上网查资料后都了解到,stage1阶段的启动代码,主要就在start.s文件里。此start.s也是系统上电后执行的第一个代码。它全部由汇编编写。在讲述start.s之前,我们先来了解一下,系统怎么知道它要先去star...

C# 生成word文档(NPOI)

using NPOI.XWPF.UserModel XWPFDocument doc = new XWPFDocument(); //创建新的word文档 XWPFParagraph p1 = doc.CreateParagraph(); //向新文档中添加段落 p1.SetAlignment(ParagraphAlignment.CENTER); //段...