码迷,mamicode.com
首页 > 其他好文 > 详细

过滤器的使用

时间:2019-04-20 11:24:10      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:https   合规   根据   需要   one   原理   访问   ext   rate   

 

 

一、过滤器

  过滤器是处于客户端与服务器资源文件之间的一道过滤网,在访问资源文件之前,通过一系列的过滤器对请求进行修改、判断等,把不符合规则的请求在中途拦截或修改。也可以对响应进行过滤,拦截或修改响应。

二、过滤器的功能

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

三、工作原理图

 

技术图片

关键代码:

技术图片
package com.fakelogin.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;

public class MyFilter implements Filter{

    @Override
    public void destroy() {
        // TODO Auto-generated method stub
        
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        // TODO Auto-generated method stub


        request.setCharacterEncoding("UTF-8");

        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");

        chain.doFilter(request, response);
    }

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        // TODO Auto-generated method stub
        System.out.println("--------Filter初始化-------");
    }

}

MyFilter
View Code
技术图片
<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.5"
    xmlns="http://java.sun.com/xml/ns/javaee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
        http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
        
  <welcome-file-list> 
    <welcome-file>  login.html </welcome-file>
    <welcome-file>  login.htm </welcome-file>
    <welcome-file>  login.jsp </welcome-file>
  </welcome-file-list>
 
   <filter>
     <filter-name>MyFilter</filter-name>
     <filter-class>com.fakelogin.filter.MyFilter</filter-class>
   </filter>
   
   <filter-mapping>
        <filter-name>MyFilter</filter-name>
        <!-- 拦截所有的请求 -->
        <url-pattern>/*</url-pattern>
   </filter-mapping>
   
  <servlet>
    <servlet-name>LoginServlet</servlet-name>
    <servlet-class>com.fakelogin.servlet.LoginServlet</servlet-class>
  </servlet>
 
  <servlet-mapping>
    <servlet-name>LoginServlet</servlet-name>
    <url-pattern>/servlet/LoginServlet</url-pattern>
  </servlet-mapping>
  


  
</web-app>

web.xml
View Code

技术图片

技术图片

 

过滤器的使用

标签:https   合规   根据   需要   one   原理   访问   ext   rate   

原文地址:https://www.cnblogs.com/wajp/p/10740268.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!