欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot攔截器Interceptor與過濾器Filter深度解析(區(qū)別、實現(xiàn)與實戰(zhàn)指南)

 更新時間:2025年06月17日 11:53:34   作者:設計師zhang  
對比SpringBoot攔截器與過濾器在執(zhí)行順序、作用范圍、異常處理等核心差異,指導開發(fā)實踐與選型策略,強調攔截器適合Web層通用邏輯,過濾器用于底層處理,建議結合APM工具優(yōu)化性能,感興趣的朋友跟隨小編一起看看吧

Spring Boot攔截器(Interceptor)與過濾器(Filter)深度解析:區(qū)別、實現(xiàn)與實戰(zhàn)指南

一、核心概念對比

1. 本質區(qū)別

維度過濾器(Filter)攔截器(Interceptor)
規(guī)范層級Servlet規(guī)范(J2EE標準)Spring MVC框架機制
作用范圍所有請求(包括靜態(tài)資源)只處理Controller請求
依賴關系不依賴Spring容器完全集成Spring IOC容器
執(zhí)行順序最先執(zhí)行(在DispatcherServlet之前)在DispatcherServlet之后執(zhí)行
異常處理無法直接使用Spring的異常處理機制可以通過@ControllerAdvice統(tǒng)一處理

2. 執(zhí)行流程示意圖

HTTP Request
  ↓
Filter Chain(doFilter)
  ↓
DispatcherServlet
  ↓
Interceptor.preHandle
  ↓
Controller Method
  ↓
Interceptor.postHandle
  ↓
View Rendering(如有)
  ↓
Interceptor.afterCompletion
  ↓
Filter Chain(返回響應)

二、過濾器(Filter)開發(fā)指南

1. 基礎實現(xiàn)方式

@Component
public class LogFilter implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, 
                         FilterChain chain) throws IOException, ServletException {
        long startTime = System.currentTimeMillis();
        HttpServletRequest req = (HttpServletRequest) request;
        // 前置處理
        System.out.println("Request URI: " + req.getRequestURI());
        chain.doFilter(request, response); // 放行請求
        // 后置處理
        long duration = System.currentTimeMillis() - startTime;
        System.out.println("Request completed in " + duration + "ms");
    }
}

2. 高級配置技巧

@Configuration
public class FilterConfig {
    @Bean
    public FilterRegistrationBean<LogFilter> loggingFilter() {
        FilterRegistrationBean<LogFilter> registration = new FilterRegistrationBean<>();
        registration.setFilter(new LogFilter());
        registration.addUrlPatterns("/api/*");
        registration.setOrder(Ordered.HIGHEST_PRECEDENCE); // 設置優(yōu)先級
        return registration;
    }
}

典型應用場景

  • 請求日志記錄
  • 全局字符編碼設置
  • 跨域處理(CORS)
  • XSS防御過濾
  • 請求內容壓縮/解壓

三、攔截器(Interceptor)開發(fā)指南

1. 標準實現(xiàn)模板

@Component
public class AuthInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, 
                           HttpServletResponse response, 
                           Object handler) throws Exception {
        String token = request.getHeader("Authorization");
        if (!validateToken(token)) {
            response.sendError(401, "Invalid token");
            return false; // 中斷請求
        }
        return true;
    }
    @Override
    public void postHandle(HttpServletRequest request, 
                          HttpServletResponse response, 
                          Object handler,
                          ModelAndView modelAndView) throws Exception {
        // Controller方法執(zhí)行后,視圖渲染前
    }
    @Override
    public void afterCompletion(HttpServletRequest request, 
                               HttpServletResponse response, 
                               Object handler, 
                               Exception ex) throws Exception {
        // 請求完全結束后(包括視圖渲染)
    }
}

2. 注冊攔截器配置

@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Autowired
    private AuthInterceptor authInterceptor;
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(authInterceptor)
                .addPathPatterns("/**")
                .excludePathPatterns("/login", "/public/**");
    }
}

典型應用場景

  • 接口權限驗證
  • 請求參數(shù)預處理
  • 接口耗時監(jiān)控
  • 敏感操作日志
  • 數(shù)據(jù)綁定前校驗

四、核心差異深度解析

1. 執(zhí)行順序對比實驗

配置多個過濾器和攔截器時的執(zhí)行順序:

Filter1 → Filter2 → Interceptor.preHandle 
→ Controller 
→ Interceptor.postHandle 
→ Interceptor.afterCompletion 
→ Filter2 → Filter1

2. 異常處理差異

// 在過濾器中處理異常
public void doFilter(...) {
    try {
        chain.doFilter(request, response);
    } catch (Exception e) {
        response.sendError(500, "Server Error");
    }
}
// 在攔截器中處理異常
@ControllerAdvice
public class GlobalExceptionHandler {
    @ExceptionHandler(Exception.class)
    public ResponseEntity<?> handleException(Exception e) {
        return ResponseEntity.internalServerError().body("Error occurred");
    }
}

3. 異步請求處理

// 攔截器需實現(xiàn)AsyncHandlerInterceptor
@Override
public void afterConcurrentHandlingStarted(HttpServletRequest request, 
                                          HttpServletResponse response, 
                                          Object handler) {
    // 異步請求的特殊處理
}

五、最佳實踐與選型策略

1. 技術選型決策樹

是否需要處理靜態(tài)資源?
├─ 是 → 必須使用Filter
└─ 否 → 
   是否需要訪問Spring Bean?
   ├─ 是 → 選擇Interceptor
   └─ 否 → 
      是否需要最早處理請求?
      ├─ 是 → 選擇Filter
      └─ 否 → 根據(jù)業(yè)務復雜度選擇

2. 性能優(yōu)化建議

  • 過濾器:避免在過濾器中做復雜業(yè)務邏輯
  • 攔截器:preHandle方法盡量輕量化
  • 兩者都應避免:
    • 同步阻塞操作
    • 頻繁的IO操作
    • 大對象的內存操作

3. 常見陷阱規(guī)避

  • 過濾器
    • 忘記調用chain.doFilter()導致請求阻塞
    • 修改請求參數(shù)未使用Wrapper類
  • 攔截器
    • 在postHandle中修改ModelAndView導致NPE
    • 異步請求中誤用afterCompletion

六、實戰(zhàn)案例演示

案例1:接口耗時監(jiān)控系統(tǒng)

// 攔截器實現(xiàn)
public class MetricsInterceptor implements HandlerInterceptor {
    private static final ThreadLocal<Long> startTime = new ThreadLocal<>();
    @Override
    public boolean preHandle(...) {
        startTime.set(System.currentTimeMillis());
        return true;
    }
    @Override
    public void afterCompletion(...) {
        long duration = System.currentTimeMillis() - startTime.get();
        metricsService.recordRequestTime(request.getRequestURI(), duration);
        startTime.remove();
    }
}

案例2:全局防重放攻擊過濾器

public class ReplayAttackFilter implements Filter {
    private Cache<String, Boolean> requestCache = 
        Caffeine.newBuilder().expireAfterWrite(5, TimeUnit.MINUTES).build();
    @Override
    public void doFilter(...) {
        String nonce = request.getHeader("X-Nonce");
        if (requestCache.getIfPresent(nonce) != null) {
            response.sendError(400, "Duplicate request");
            return;
        }
        requestCache.put(nonce, true);
        chain.doFilter(request, response);
    }
}

七、擴展知識

1. 與AOP的區(qū)別

  • AOP
    • 基于代理模式實現(xiàn)
    • 可以精確控制到具體方法
    • 更適合業(yè)務層面的切面處理
  • 攔截器
    • 基于HandlerMapping實現(xiàn)
    • 主要針對HTTP請求生命周期
    • 更適合Web層通用處理

2. 高級應用場景

  • 過濾器鏈:實現(xiàn)責任鏈模式
  • 攔截器棧:組合多個攔截邏輯
  • 動態(tài)啟用/禁用:結合配置中心實現(xiàn)

總結建議

  • 優(yōu)先使用攔截器處理Web層通用邏輯
  • 保留過濾器用于底層請求處理
  • 復雜場景可以組合使用兩者
  • 生產(chǎn)環(huán)境務必進行性能壓測

通過合理運用過濾器和攔截器,開發(fā)者可以構建出高可維護性的Web應用架構。建議結合APM工具(如SkyWalking)監(jiān)控兩者的執(zhí)行效率,持續(xù)優(yōu)化系統(tǒng)性能。

到此這篇關于Spring Boot攔截器Interceptor與過濾器Filter深度解析(區(qū)別、實現(xiàn)與實戰(zhàn)指南)的文章就介紹到這了,更多相關Spring Boot攔截器Interceptor與過濾器Filter區(qū)別內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MybatisPlus將自定義的sql列表查詢返回改為分頁查詢

    MybatisPlus將自定義的sql列表查詢返回改為分頁查詢

    本文主要介紹了MybatisPlus將自定義的sql列表查詢返回改為分頁查詢,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-04-04
  • Java單例模式分析

    Java單例模式分析

    這篇文章主要給大家介紹了關于Java單例模式,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2021-09-09
  • 使用遞歸算法結合數(shù)據(jù)庫解析成Java樹形結構的代碼解析

    使用遞歸算法結合數(shù)據(jù)庫解析成Java樹形結構的代碼解析

    這篇文章主要介紹了使用遞歸算法結合數(shù)據(jù)庫解析成Java樹形結構的代碼解析的相關資料,需要的朋友可以參考下
    2017-09-09
  • Java之Mybatis的二級緩存

    Java之Mybatis的二級緩存

    本文主要介紹Java中Mybatis的二級緩存,緩存就是一塊內存空間,保存臨時數(shù)據(jù),它是SqlSessionFactory的緩存,對Mybaits感興趣的小伙伴可以參考閱讀
    2023-03-03
  • mybatis查詢語句的背后揭秘

    mybatis查詢語句的背后揭秘

    這篇文章主要給大家介紹了關于mybatis查詢語句的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mybatis具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • 詳解如何在Java中實現(xiàn)屏幕共享

    詳解如何在Java中實現(xiàn)屏幕共享

    在本文中,將為大家展示如何利用 JxBrowser 的功能,實現(xiàn)運行在不同電腦上的兩個 Java 應用程序之間的屏幕共享,感興趣的小伙伴可以參考一下
    2024-10-10
  • Spring詳細講解事務失效的場景

    Spring詳細講解事務失效的場景

    實際項目開發(fā)中,如果涉及到多張表操作時,為了保證業(yè)務數(shù)據(jù)的一致性,大家一般都會采用事務機制,好多小伙伴可能只是簡單了解一下,遇到事務失效的情況,便會無從下手,下面這篇文章主要給大家介紹了關于Spring事務失效場景的相關資料,需要的朋友可以參考下
    2022-07-07
  • 關于Spring事務隔離、傳播屬性與@Transactional注解

    關于Spring事務隔離、傳播屬性與@Transactional注解

    這篇文章主要介紹了關于事務隔離、Spring傳播屬性與@Transactional注解,如果一組處理步驟或者全部發(fā)生或者一步也不執(zhí)行,我們稱該組處理步驟為一個事務,需要的朋友可以參考下
    2023-05-05
  • Java優(yōu)雅的關閉線程池的方法

    Java優(yōu)雅的關閉線程池的方法

    本文主要介紹了Java如何優(yōu)雅的關閉線程池,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • MongoDB中ObjectId的誤區(qū)及引起的一系列問題

    MongoDB中ObjectId的誤區(qū)及引起的一系列問題

    這篇文章主要介紹了MongoDB中ObjectId的誤區(qū)及引起的一系列問題,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12

最新評論