亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot實現過濾器攔截器的耗時實例對比分析

發布時間:2022-07-04 10:09:58 來源:億速云 閱讀:266 作者:iii 欄目:開發技術

本篇內容介紹了“SpringBoot實現過濾器攔截器的耗時實例對比分析”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

過濾器的方式

這種方式簡單點 但是可配置性不高

注意:一定得掃描到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實現過濾器攔截器的耗時實例對比分析

“SpringBoot實現過濾器攔截器的耗時實例對比分析”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

四平市| 潜江市| 阿鲁科尔沁旗| 成武县| 寿光市| 获嘉县| 武功县| 罗江县| 郯城县| 佛学| 峨眉山市| 大丰市| 湟源县| 肥东县| 家居| 界首市| 蓬溪县| 星座| 霍林郭勒市| 上林县| 聂荣县| 荥经县| 垦利县| 连云港市| 诸城市| 平度市| 郎溪县| 宿松县| 临漳县| 壤塘县| 宜阳县| 宣武区| 阆中市| 乌兰察布市| 永清县| 望城县| 翼城县| 桂阳县| 镇赉县| 渭南市| 连山|