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);
}
}
结果
总结
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);
}
}
测试结果
来源: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