SpringBoot实现过滤器 * 的耗时对比

作者:look-word 时间:2022-04-12 00:45:04 

三种方式 下面为大家一一对应

  • 过滤器的方式

  • * 的方式

过滤器的方式

这种方式简单点 但是可配置性不高

注意:一定得扫描到spring容器中

创建一个类 实现 filter接口

  • init:该方法是对filter对象进行初始化的方法,仅在容器初始化filter对象结束后被调用一次,参数FilterConfig可以获得filter的初始化参数;

  • doFilter:可以对request和response进行<u>预处理</u>其中FilterChain可以将处理后的request和response对象传递到过滤链上的下一个资源。

  • destroy():该方法在容器销毁对象前被调用。

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

@Component
public class LogFilter implements Filter {

private static final Logger LOG = LoggerFactory.getLogger(LogFilter.class);

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

}

@Override
   public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
       // 打印请求信息
       HttpServletRequest request = (HttpServletRequest) servletRequest;
       LOG.info("------------- LogFilter 开始 -------------");
       LOG.info("请求地址: {} {}", request.getRequestURL().toString(), request.getMethod());
       LOG.info("远程地址: {}", request.getRemoteAddr());

long startTime = System.currentTimeMillis();
       filterChain.doFilter(servletRequest, servletResponse);
       LOG.info("------------- LogFilter 结束 耗时:{} ms -------------", System.currentTimeMillis() - startTime);
   }
}

结果

SpringBoot实现过滤器 * 的耗时对比

总结

1.过滤器用来实现通用的功能,减少代码冗余,提高可维护性;

2.一个过滤器可以配置给多个资源使用(编码过滤器);

3.一个资源也可以配置多个过滤器,按照配置顺序调用。

* 的方式

如果不懂 请先看了 介绍再来

* 的介绍

话不说多 直接上代码

创建 *

/**
* * :Spring框架特有的,常用于登录校验,权限校验,请求日志打印 /login
* @author : look-word
* 2022-06-26 13:55
**/
@Component
public class LogInterceptor implements HandlerInterceptor {
   private static final Logger LOG = LoggerFactory.getLogger(LogInterceptor.class);

@Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 打印请求信息
        LOG.info("------------- LogInterceptor 开始 -------------");
        LOG.info("请求地址: {} {}", request.getRequestURL().toString(), request.getMethod());
        LOG.info("远程地址: {}", request.getRemoteAddr());

long startTime = System.currentTimeMillis();
        request.setAttribute("requestStartTime", startTime);
        return true;
    }

@Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        long startTime = (Long) request.getAttribute("requestStartTime");
        LOG.info("------------- LogInterceptor 结束 耗时:{} ms -------------", System.currentTimeMillis() - startTime);
    }
}

注册 *

把我们的 * 注册到 * 链中

/**
* @author : look-word
* 2022-06-26 14:03
**/
@Configuration
public class SpringMvcConfig implements WebMvcConfigurer {

@Resource
   private LogInterceptor logInterceptor;
   /**
    * 注册 *
    * @param registry
    */
   @Override
   public void addInterceptors(InterceptorRegistry registry) {
       registry
               .addInterceptor(logInterceptor)
               .addPathPatterns("/**")// 对那些接口拦截
               .excludePathPatterns("/login");// 对哪些接机口放行
       WebMvcConfigurer.super.addInterceptors(registry);
   }
}

测试结果

SpringBoot实现过滤器 * 的耗时对比

来源:https://www.cnblogs.com/look-word/p/16415322.html

标签:SpringBoot,过滤器, ,
0
投稿

猜你喜欢

  • SpringMVC中事务是否可以加在Controller层的问题

    2021-12-09 01:20:15
  • C#串口连接的读取和发送详解

    2022-05-11 10:04:47
  • SpringBoot请求处理之常用参数注解介绍与源码分析

    2023-11-10 10:38:12
  • SpringBoot 二维码生成base64并上传OSS的实现示例

    2023-05-12 04:41:33
  • Mybatis配置解析看这一篇就够了

    2023-05-15 22:42:12
  • Mybatis实现单个和批量定义别名typeAliases

    2023-02-11 06:27:03
  • C#启动进程的几种常用方法

    2023-06-18 04:13:48
  • 一篇文章带你入门Springboot沙箱环境支付宝支付(附源码)

    2021-06-26 23:21:16
  • IDEA新建springboot项目时未生成pom.xml文件的解决操作

    2022-08-22 03:16:31
  • Java动态添加view的方法

    2023-06-11 04:20:38
  • 使用spring注入枚举类型作为参数

    2023-11-23 13:25:57
  • Maven profile实现不同环境的配置管理实践

    2021-11-11 09:52:15
  • java方法及this关键字原理分析详解

    2021-08-16 07:51:35
  • Java使用Scanner类进行控制台输入实现方法

    2021-08-08 18:34:26
  • java实现对Hadoop的操作

    2021-10-05 16:30:37
  • Java基础之多线程

    2022-11-30 11:01:43
  • Spring高阶用法之自定义业务对象组件化

    2022-02-18 07:48:55
  • 详解SpringBoot下文件上传与下载的实现

    2021-08-15 15:44:13
  • Java数据结构之实现哈希表的分离链接法

    2023-09-06 04:50:17
  • Android 消息机制详解及实例代码

    2023-07-28 08:37:49
  • asp之家 软件编程 m.aspxhome.com