簡單總結SpringMVC攔截器的使用方法

SpringMVC攔截器

攔截器類似於Filter過濾器,它是springMVC特有的,它可以預處理和後處理,我們可以定義一些攔截器來實現特定的業務。

過濾器與攔截器本質區別:

(1)攔截器時AOP思想的具體應用(一個橫切面,直接切進請求響應中去)。

(2)攔截器時spring MVC特有的。

(3)攔截器隻會攔截 訪問控制器的方法,如果訪問靜態資源如:.jsp/html/css/image/js 時,它不會去攔截,而Filter過濾器無論什麼都會去攔截。

自定義攔截器需要兩步:

第一步:編寫自定義類實現 HandlerInterceptor 接口,且必須重寫方法;

第二步:在配置類中,註冊攔截器,實現 WebMvcConfigurer接口,重寫對應的方法;關於配置類                 我在這邊文章有記錄:https://www.jb51.net/article/204128.htm

(1)public boolean preHandle() {}

請求前處理的邏輯 – 前置。
方法返回值:返回佈爾值,返回true表示可以執行後續代碼,返回false程序會終止。

(2)public void postHandle(){}

請響應前處理的邏輯 – 後置。
方法返回值:無返回值。

目錄:

package com.lxc.springboot.interceptor;
 
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
 
@Component
public class MyInterceptor implements HandlerInterceptor {
    private static final Logger LOG = LoggerFactory.getLogger(LogInterceptor.class);
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        s
        // 攔截前的操作
        System.out.println("-----------前置攔截-----------");
        return true;
    }
    
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        // 攔截後的操作
        System.out.println("------------後置攔截------------");
    }
 
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        // 可以做一些清理工作
    }
}

註冊攔截器:

package com.lxc.springboot.config;
 
 
import com.lxc.springboot.intercetor.MyInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
 
import javax.annotation.Resource;
 
/**
 * @擴展springMVC
 * 第一步:
 * @Configuration 註解的作用:讓這個類變為配置類
 * 第二步:
 * 必須實現 WebMvcConfigurer 接口
 */
@Configuration
public class SpringMvcConfig implements WebMvcConfigurer {
    @Resource
    private MyInterceptor myInterceptor;
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // addInterceptor():註冊攔截器,參數是一個攔截器
        // addPathPatterns(): 路徑映射,哪些路徑需要被攔截,/** 全部攔截
        // excludePathPatterns(): 排除哪些路徑,不會被攔截
        registry.addInterceptor(myInterceptor)
                .addPathPatterns("/**")
                .excludePathPatterns("/login");
    }
}

小例子

跟Filter一樣,記錄接口的請求響應耗時:

package com.lxc.springboot.interceptor;
 
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
/**
 * 這個是攔截器,與過濾器區別:
 *
 * 【【【【特別註意:增加攔截器,還需要在config中增加一個配置類!配置】】】】
 *
 * (1)攔截器是spring特有的,經常用於登錄校驗、權限驗證、請求打印日志等等。
 * (2)攔截器不需要你手動調用後續代碼執行,它是有兩個方法的,且分開的,一個前,一個後
 * (3)而過濾器,我們會在打印日志的中間,使用filterChain.doFilter()方法去調用後續代碼執行的!
 * (4)攔截器的 preHandle 前置處理方法,必須返回true,否則後續邏輯不會執行,整個業務也會結束!
 */
@Component // 增加這個註解,讓spring能掃描到這個類
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("【全局攔截器】");
        LOG.info("*********** InterceptorLog日志開始 *********** ");
        LOG.info("* 請求地址: {}, 方法: {}", request.getRequestURL().toString(), request.getMethod());
        LOG.info("* 遠程地址: {}, 域名: {}, 端口: {}", request.getRemoteAddr(), request.getRemoteHost(), request.getRemotePort());
        long startTime = System.currentTimeMillis();
        request.setAttribute("boot-responseTime", startTime);
        return true;
    }
 
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        // request.getAttribute("boot-responseTime") 返回的是Object
        long startTimed = (long) request.getAttribute("boot-responseTime");
        LOG.info(" *********** InterceptorLog 結束,耗時: {} ms *********** ", System.currentTimeMillis() - startTimed);
    }
}

在配置類中註冊攔截器:

package com.lxc.springboot.config;
 
import com.lxc.springboot.intercetor.LogInterceptor;
import com.lxc.springboot.intercetor.MyInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
 
import javax.annotation.Resource;
 
@Configuration
public class SpringMvcConfig implements WebMvcConfigurer {
    @Resource
    private MyInterceptor myInterceptor;
    @Resource
    private LogInterceptor logInterceptor;
    
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(logInterceptor)
                .addPathPatterns("/**")
                .excludePathPatterns("/login");
    }
    
}

測試:

到此這篇關於簡單總結SpringMVC攔截器的使用方法的文章就介紹到這瞭,更多相關SpringMVC攔截器內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: