• SpringBoot中使用Filter


    SpringBoot中使用Filter.md

    现在我们通过过滤器来实现记录请求执行时间的功能,其实现如下:

    package com.cuianbing.filter;
    
    
    public class LogRequestCostFilter implements Filter {
    
        @Override
        public void init(FilterConfig filterConfig) throws ServletException {
        }
    
        @Override
        public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
                throws IOException, ServletException {
            long start = System.currentTimeMillis();
            filterChain.doFilter(servletRequest, servletResponse);
            System.out.println("LogRequestCostFilter Execute cost=" + (System.currentTimeMillis() - start));
        }
    
        @Override
        public void destroy() {
        }
    }
    
    

    这段代码是在方法执行前先记录时间戳,然后通过过滤器完成请求的执行,在返回结果之间计算执行的时间。这里需要主要,这个类必须继承Filter类,这个是Servlet的规范,这个跟以前的Web项目没区别。但是,有了过滤器类以后,以前的web项目可以在web.xml中进行配置,但是spring boot项目并没有web.xml这个文件,在Spring boot中,需要FilterRegistrationBean来完成配置。其实现过程如下:

    package com.cuianbing.filter;
    @Configuration
    public class FilterConfig {
     
        @Bean
        public FilterRegistrationBean registFilter() {
            FilterRegistrationBean registration = new FilterRegistrationBean();
            registration.setFilter(new LogRequestCostFilter());
            registration.addUrlPatterns("/*");
            registration.setName("LogRequestCostFilter");
            registration.setOrder(1);
            return registration;
        }
    }
    

    除了通过 FilterRegistrationBean 来配置以外,还有一种更直接的办法,直接通过注解就可以完成了:

    package com.cuianbing.filter;
    
    @WebFilter(urlPatterns = "/*", filterName = "LogRequestCostFilter2")
    public class LogRequestCostFilter2 implements Filter {
        @Override
        public void init(FilterConfig filterConfig) throws ServletException {
        }
     
        @Override
        public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
            long start = System.currentTimeMillis();
            filterChain.doFilter(servletRequest, servletResponse);
            System.out.println("LogRequestCostFilter2 Execute cost=" + (System.currentTimeMillis() - start));
        }
     
        @Override
        public void destroy() {
        }
    }
    

    这里直接用@WebFilter就可以进行配置,同样,可以设置url匹配模式,过滤器名称等。这里需要注意一点的是@WebFilter这个注解是Servlet3.0的规范,并不是Spring boot提供的。除了这个注解以外,我们还需在配置类中加另外一个注解:@ServletComponetScan,指定扫描的包。

    package com.cuianbing.filter;
    
    @SpringBootApplication
    @ServletComponentScan("com.cuianbing.filter")
    public class Application {
        public static void main(String[] args) throws Exception {
            SpringApplication.run(Application.class, args);
        }
    }
    

    细心的读者会发现,第二个Filter我们并没有指定执行的顺序,但是却在第一个Filter之前执行。这里需要解释一下,@WebFilter这个注解并没有指定执行顺序的属性,其执行顺序依赖于Filter的名称,是根据Filter类名(注意不是配置的filter的名字)的字母顺序倒序排列,并且@WebFilter指定的过滤器优先级都高于FilterRegistrationBean配置的过滤器。有兴趣的朋友可以自己实验一下。

  • 相关阅读:
    MySQL数据库可以用任意ip连接访问的方法
    Docker packaging guide for Python
    Alpine makes Python Docker builds 50× slower, and images 2× larger
    hasura graphql-engine v1.0 发布了
    edgedb 1.0 Alpha 2 了
    aceql-http docker 试用
    deno学习五 typescript + vscode 集成
    makeself 试用
    poolifier nodejs 线程池工具
    Java Command Line Parsers Comparison
  • 原文地址:https://www.cnblogs.com/cuianbing/p/16339670.html
Copyright © 2020-2023  润新知