过滤器(Filter);

一.过滤器

1.  介绍

         Filter 即为过滤,用于在 Servlet 之外对 Request 或者 Response 进行修改。它主要用于对用户请求进行预处理,也可以对 HttpServletResponse 进行后处理。使用 Filter 的完整流程: Filter 对用户请求进行预处理,接着将请求交给 Servlet进行处理并生成响应,最后 Filter 再 对服务器响应进行后处理。在一个 web 应用中,可以开发编写多个 Filter,这些 Filter 组合 起来称之为一个 Filter 链。

过滤器(Filter);_第1张图片

     若是一个过滤器链:先配置先执行(请求时的执行顺序);响应时: 以相反的顺序执行 .

     在 HttpServletRequest 到达 Servlet 之前,拦截客户的 HttpServletRequest 。根据需要检查 HttpServletRequest,也可以修改 HttpServletRequest 头和数据。

      在 HttpServletResponse 到达客户端之前,拦截 HttpServletResponse。根据需要检查 HttpServletResponse,也可以修改 HttpServletResponse 头和数据。

2.  实现

我们可以通过实现一个叫做 javax.servlet.Fileter 的接口来实现一个过滤器,其中定义了 三个方法,init(), doFilter(), destroy()分别在相应的时机执行。后期观察生命周期。 Filter 的实现只需要两步:

Step1: 编写 java 类实现 Filter 接口,并实现其 doFilter 方法;

Step2: 在 web.xml 文件中对编写的 filter 类进行注册,并设置它所能拦截的资源 

过滤器(Filter);_第2张图片

过滤器(Filter);_第3张图片

           Filter 接口中有一个 doFilter 方法,当开发人员编写好 Filter,并配置对哪个 web 资源进行拦截后,Web 服务器每次在调用 web 资源的 service 方法之前,都会先调用一下 filter 的 doFilter 方法。因此可以达到如下效果:

            调用目标资源之前,让一段代码执行。

            是否调用目标资源(即是否让用户访问 web 资源)。

            web 服务器在调用 doFilter 方法时,会传递一个 filterChain 对象进来,filterChain 对象是 filter 接口中最重要的一个对象,它提供了一个 doFilter 方法,开发人员可以根据需求决定 是否调用此方法,调用该方法,则 web 服务器就会调用 web 资源的 service 方法,即 web 资源就会被访问,否则 web 资源不会被访问。(本质是放行,调用 doFilter 方法后,即请求可以到达资源

过滤器(Filter);_第4张图片

url-pattern 的配置:

1).配置具体路径/index.html/TestServlet.do;

2).带有通配符的配置*.do /* /user/* *.html *.jsp

3.  过滤器执行的顺序

           通过观察 web.xml 中的配置和各个 filter 的执行顺序,找出 filter 执行先后的依据。根据之前观察 Servlet 生命周期的的方式,观察一下过滤器的生命周期。

实例:

1.过滤器解决字符乱码

/**
 * 字符集乱码解决
 * 
 * 						POST请求										GET请求
 * 	Tomcat8以及以上版本		会乱码
 * 						request.setCharacterEncoding("UTF-8");		不会乱码,不用处理
 * 																	如果通过new String()去转换反而会乱码
 * 
 * 	Tomcat7及以下版本		会乱码										会乱码
 * 						request.setCharacterEncoding("UTF-8");		new String(request.getParameter("name").getBytes("ISO-88959-1"),"utf-8")
 * 	
 */
public class EncodingFilter implements Filter {

    public EncodingFilter() {
    	
    }

	public void destroy() {
		
	}

	public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException {
		
		// 基于HTTP
		HttpServletRequest request = (HttpServletRequest) req;
		HttpServletResponse response = (HttpServletResponse) resp;
		
		// 设置POST请求乱码问题 (只针对POST,GET请求无效并不受影响)
		request.setCharacterEncoding("UTF-8");
		
		
		// 判断请求类型 (GET/POST)
		String method = request.getMethod();
		// 判断是否是GET请求
		if ("GET".equalsIgnoreCase(method)) {
			// 得到服务器的版本
			String serverInfo = request.getServletContext().getServerInfo(); // Apache Tomcat/8.0.45
			// 截取字符串得到服务器版本号
			String versionStr =  serverInfo.substring(serverInfo.indexOf("/")+1,serverInfo.indexOf("."));
			// 判断是否是Tomcat7及以下版本
			if (versionStr != null && Integer.parseInt(versionStr) < 8) {
				// GET请求处理
				HttpServletRequest request2 = new MyWapper(request);
				// 放行资源
				chain.doFilter(request2, response);
				return;
			}
			
		}
		
		// 放行资源
		chain.doFilter(request, response);
	}

	public void init(FilterConfig fConfig) throws ServletException {
		
	}

}



/**
 * 1、定义类,继承HttpServletRequestWrapper包装类
 * 2、重写getParameter方法
 * 3、在重写的方法中处理乱码问题
 * @author Lisa Li
 *
 */
class MyWapper extends HttpServletRequestWrapper {

	private HttpServletRequest request;
	public MyWapper(HttpServletRequest request) {
		super(request);
		this.request = request;
	}

	/**
	 * 重写getParameter()方法
	 */
	@Override
	public String getParameter(String name) {
		
		String value = null;
		try {
			value = new String(request.getParameter(name).getBytes("ISO-8859-1"),"UTF-8");
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		}
		return value;
	}
	
	
	
}

 

 

 

 

 

 

 

 

你可能感兴趣的:(后端,web,前后端交互)