过滤器

1.过滤器的作用

  对服务器接受的请求资源和响应给浏览器的资源进行管理

  保护servlet

2.过滤器的使用

  创建一个实现Filter接口的普通java类

  覆写接口的方法

    init():服务器启动执行,资源初始化

    doFilter():拦截请求的方法,在此方法中可以对资源实现管理

      注意:

        需要手动对请求进行放行,chain.doFilter(request,response)

    destroy():服务器关闭执行

  在web.xml中配置过滤器

<!--配置过滤器-->
<filter>
    <filter-name>myFilter</filter-name>
    <filter-class>com.mxj.MyFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>myFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

  注意:

    url-pattern:/*  拦截所有的请求

    url-pattern:*.do  拦截所有以.do结尾的请求,一般用来进行模块拦截

    url-pattern:/ts  表示拦截指定url的请求,针对某个servlet的请求进行拦截,保护servlet

  过滤器的声明周期:

    服务器启动到服务器关闭

  总结:

    过滤器由程序员声明和配置,服务器根据请求中的uri信息调用

  执行:

    浏览器发起请求到服务器,服务器接收到请求后,根据URI信息在web.xml中找到对应的过滤器执行doFilter方法,该方法对此次请求进行处理后如果符合要求则放行,放行后如果还有符合要求的过滤器则继续进行过滤,直到执行对应的servlet进行请求处理。servlet对请求处理完毕后,也就是service方法结束,还需继续返回相应的doFilter方法继续执行

  案例:

    统一编码格式设置

    session管理

    权限管理

    资源管理(统一水印,和谐词汇等等)

public class MyFilter implements Filter {
    @Override
    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
            throws IOException, ServletException {
        //设置编码格式
        req.setCharacterEncoding("utf-8");
        resp.setContentType("text/html;charaset=utf-8");
        //判断session
        HttpSession hs=((HttpServletRequest) req).getSession();
        if(hs.getAttribute("user")==null){
            ((HttpServletResponse)resp).sendRedirect("/a/login.jsp");    
        }
        else{
            //放行
            chain.doFilter(req, resp);
        }
        
    }
}
原文地址:https://www.cnblogs.com/mxj961116/p/11178321.html