JavaWeb过滤器和监听器使用介绍

过滤器和监听器

Filter

Filter 表示过滤器,是 JavaWeb 三大组件(Servlet、Filter、Listener)之一

过滤器可以把对资源的请求拦截下来,从而实现一些特殊的功能。

过滤器一般完成一些通用的操作,比如:权限控制、统一编码处理、敏感字符处理等等…

Filter快速入门

过滤器的使用步骤如下:

定义类,实现 Filter接口,并重写其所有方法; 注意Filter是javax.servlet包下的, 不要导错包

public class FilterDemo implements Filter {
    
    
  	@Override
    public void init(FilterConfig filterConfig) throws ServletException {
    
    
        
    }
  
		@Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    
    

    }

  	@Override
    public void destroy() {
    
    

    }
}

配置Filter拦截资源的路径:在类上定义 @WebFilter 注解; /*表示所有路径都拦截

@WebFilter("/*")
public class FilterDemo implements Filter {
    
    
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    
    

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    
    

    }

    @Override
    public void destroy() {
    
    

    }
}

在doFilter方法中输出一句话,并放行

@WebFilter("/*")
public class FilterDemo implements Filter {
    
    
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    
    
        // 输出一句话
        System.out.println("FilterDemo...");
        // 放行
        filterChain.doFilter(servletRequest, servletResponse);
    }


    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    
    

    }

    @Override
    public void destroy() {
    
    

    }
}

FIlter执行流程

Filter在放行之前和放行之后都可以编写逻辑, 那么放行之前和放行之后的逻辑有什么区别么?

执行放放行前的逻辑, 然后放行去访问对应资源; 资源访问完成后在进行响应时, 还是会经过过滤器Filter的; 此时回到Filter中, 是不会重头执行的, 只会执行放行后的逻辑

放行前: 一般对request数据进行处理

放行后: 一般对response数据进行处理

在这里插入图片描述

FIlter使用细节

Filter拦截路径配置:

Filter 可以根据需求,配置不同的拦截资源路径

  • 拦截具体的资源:/index.jsp:只有访问index.jsp时才会被拦截。
  • 目录拦截:/user/*:访问/user下的所有资源,都会被拦截
  • 后缀名拦截:*.jsp:访问后缀名为jsp的资源,都会被拦截
  • 拦截所有:/*:访问所有资源,都会被拦截

过滤器链

一个Web应用,可以配置多个过滤器,这多个过滤器称为过滤器链

在这里插入图片描述

注意: 多个注解配置的Filter直接,优先级按照过滤器类名(字符串)的自然排序:

例如: AFilter > BFilter; Filter1 > Filter2

Listener

Listener 表示监听器,是 JavaWeb 三大组件(Servlet、Filter、Listener)之一

监听器现在用的非常少, 了解一下即可

监听器可以监听就是在application,session,request三个对象创建、销毁或者往其中添加修改删除属性时自动执行代码的功能组件

Listener分类:JavaWeb中提供了8个监听器

在这里插入图片描述

ServletContextListener 使用

定义类,实现ServletContextListener接口, 在类上添加@WebListener 注解

@WebListener
public class ContextLoaderListener implements ServletContextListener {
    
    
    @Override
    public void contextInitialized(ServletContextEvent sce) {
    
    
        //加载资源
        System.out.println("ContextLoaderListener...");
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
    
    
        //释放资源
    }
}

猜你喜欢

转载自blog.csdn.net/m0_71485750/article/details/127910019