SpringBoot實現(xiàn)過濾器攔截器的耗時對比
三種方式 下面為大家一一對應(yīng)
- 過濾器的方式
- 攔截器的方式
過濾器的方式
這種方式簡單點 但是可配置性不高
注意:一定得掃描到spring容器中
創(chuàng)建一個類 實現(xiàn) filter接口
- init:該方法是對filter對象進行初始化的方法,僅在容器初始化filter對象結(jié)束后被調(diào)用一次,參數(shù)FilterConfig可以獲得filter的初始化參數(shù);
- doFilter:可以對request和response進行
<u>預(yù)處理</u>
。其中FilterChain可以將處理后的
request和response對象傳遞到過濾鏈上的下一個資源。 - destroy():該方法在容器銷毀對象前被調(diào)用。
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("遠(yuǎn)程地址: {}", request.getRemoteAddr()); long startTime = System.currentTimeMillis(); filterChain.doFilter(servletRequest, servletResponse); LOG.info("------------- LogFilter 結(jié)束 耗時:{} ms -------------", System.currentTimeMillis() - startTime); } }
結(jié)果
總結(jié)
1.過濾器用來實現(xiàn)通用的功能,減少代碼冗余,提高可維護性;
2.一個過濾器可以配置給多個資源使用(編碼過濾器);
3.一個資源也可以配置多個過濾器,按照配置順序調(diào)用。
攔截器的方式
如果不懂 請先看了 介紹再來
話不說多 直接上代碼
創(chuàng)建攔截器
/** * 攔截器:Spring框架特有的,常用于登錄校驗,權(quán)限校驗,請求日志打印 /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("遠(yuǎn)程地址: {}", 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 結(jié)束 耗時:{} 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); } }
測試結(jié)果
以上就是SpringBoot實現(xiàn)過濾器攔截器的耗時對比的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot過濾器攔截器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java對MySQL數(shù)據(jù)庫進行連接、查詢和修改操作方法
這篇文章主要介紹了Java對MySQL數(shù)據(jù)庫進行連接、查詢和修改操作方法,需要的朋友可以參考下2017-07-07Java中Spring使用Quartz任務(wù)調(diào)度定時器
本篇文章主要介紹了Java中Spring使用Quartz任務(wù)調(diào)度定時器,具有一定的參考價值,有興趣的可以了解一下。2017-02-02基于springMvc+hibernate的web application的構(gòu)建
下面小編就為大家?guī)硪黄趕pringMvc+hibernate的web application的構(gòu)建。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10SpringMVC JSON數(shù)據(jù)交互實現(xiàn)過程解析
這篇文章主要介紹了SpringMVC JSON數(shù)據(jù)交互實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-10-10