• 过滤器、监听器、拦截器的区别,你都搞懂了吗?


    过滤器


    Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序,主要的用途是过滤字符编码、做一些业务逻辑判断等。

    其工作原理是,只要你在web.xml文件配置好要拦截的客户端请求,它都会帮你拦截到请求,此时你就可以对请求或响应(Request、Response)统一设置编码,简化操作;同时还可以进行逻辑判断,如用户是否已经登录、有没有权限访问该页面等等工作,它是随你的web应用启动而启动的,只初始化一次,以后就可以拦截相关的请求,只有当你的web应用停止或重新部署的时候才能销毁。

    在javax.servlet.Filter接口中定义了3个方法:

    void init(FilterConfig filterConfig) 用于完成过滤器的初始化

    void destroy() 用于过滤器销毁前,完成某些资源的回收

    void doFilter(ServletRequest request, ServletResponse response,FilterChain chain) 实现过滤功能,该方法对每个请求增加额外的处理

    package com.cn.util;  
     
    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;  
    import javax.servlet.http.HttpServletRequest;  
    import javax.servlet.http.HttpServletResponse;  
     
    public class FilterUtil implements Filter{  
     
     @SuppressWarnings("unused")  
     private FilterConfig filterConfig;  
     @Override 
     public void init(FilterConfig filterConfig) throws ServletException {  
     this.filterConfig = filterConfig;  
            System.out.println("过滤器Filter初始化");  
        }  
     
     @Override 
     public void doFilter(ServletRequest request, ServletResponse response,  
                FilterChain chain) throws IOException, ServletException {  
     if (!(request instanceof HttpServletRequest) || !(response instanceof HttpServletResponse)) {  
     throw new ServletException("FilterUtil just supports HTTP requests");  
            }  
            HttpServletRequest httpRequest = (HttpServletRequest) request;  
            HttpServletResponse httpResponse = (HttpServletResponse) response;  
            httpRequest.setCharacterEncoding(this.filterConfig.getInitParameter("encoding"));  
            httpResponse.setCharacterEncoding(this.filterConfig.getInitParameter("encoding"));  
            chain.doFilter(httpRequest, httpResponse);  
        }  
     
     @Override 
     public void destroy() {  
            System.out.println("过滤器Filter销毁");  
        }  
     
    }  
    web.xml配置:

     
     encodingFilter 
      
     com.cn.util.FilterUtil 
     true 
      
     encoding 
     UTF-8 
     
     
     
     
     encodingFilter 
     /* 
     

    监听器

    Servlet的监听器Listener,它是实现了javax.servlet.ServletContextListener接口的服务器端程序,它也是随web应用的启动而启动,只初始化一次,随web应用的停止而销毁。

    主要作用是:做一些初始化的内容添加工作、设置一些基本的内容、比如一些参数或者是一些固定的对象等等。

    在javax.servlet.ServletContextListener接口中定义了2种方法:

    void contextInitialized(ServletContextEvent sce) 监听器的初始化

    void contextDestroyed(ServletContextEvent sce) 监听器销毁

    package com.cn.util;  
     
    import javax.servlet.ServletContextEvent;  
    import javax.servlet.ServletContextListener;  
     
    public class ServletContextListenerUtil implements ServletContextListener{  
     
     //监听器的初始化 
     @Override 
     public void contextInitialized(ServletContextEvent sce) {  
            System.out.println("监听器ServletContextListenerUtil初始化");  
        }  
     
     //监听器销毁 
     @Override 
     public void contextDestroyed(ServletContextEvent sce) {  
            System.out.println("监听器ServletContextListenerUtil销毁");  
        }  
    }  

    项目启动时,先启动监听器,再启动过滤器。


    拦截器

    拦截器是在面向切面编程中应用的,就是在你的service或者一个方法前调用一个方法,或者在方法后调用一个方法比如动态代理就是拦截器的简单实现,在你调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。

    拦截器不是在web.xml配置的,比如struts在struts.xml配置,在springMVC在spring与springMVC整合的配置文件中配置。

    在springmvc中,定义拦截器要实现HandlerInterceptor接口,并实现该接口中提供的三个方法

    package com.cn.util;  
    import javax.servlet.http.HttpServletRequest;  
    import javax.servlet.http.HttpServletResponse;  
    import org.springframework.web.servlet.HandlerInterceptor;  
    import org.springframework.web.servlet.ModelAndView;  
     
    public class InterceptorUtil implements HandlerInterceptor{  
     
     //进入Handler方法之前执行 
     //可以用于身份认证、身份授权。如果认证没有通过表示用户没有登陆,需要此方法拦截不再往下执行,否则就放行 
     @Override 
     public boolean preHandle(HttpServletRequest request,  
                HttpServletResponse response, Object handler) throws Exception {  
     // TODO Auto-generated method stub 
            System.out.println("InterceptorUtil...........preHandle");  
            String user= (String) request.getSession().getAttribute("user");  
     if(user != null){  
     return true;  
            }  
            request.getRequestDispatcher("/WEB-INF/jsp/index.jsp").forward(request, response);  
     //true表示放行,false表示不放行 
     return false;  
        }  
     
     @Override 
     public void postHandle(HttpServletRequest request,  

  • 相关阅读:
    【leetcode:94.二叉树的中序遍历】
    亲子失和最大的内耗是:家长总是“说硬话,办软事”!
    Mysql_14 存储引擎
    docker小技能:容器IP和宿主机IP一致( Nacos服务注册ip为内网ip,导致Fegin无法根据服务名访问 )
    【期末复习笔记】数字逻辑
    计算机复试面试题总结
    关联分析——apprior算法
    Databend JSON 复杂数据类型的设计与使用 | Databend 特性系列
    Spring5源码解析系列一——IoC容器核心类图
    数据结构-Dijkstra最短路径算法
  • 原文地址:https://blog.csdn.net/m0_72088858/article/details/126717200