在springboot中使用攔截器的步驟詳解
在springboot中使用攔截器
攔截器Interceptor,是SpringMVC中的核心內(nèi)容,利用spring的AOP(Aspect Oriented Programming, 面向切面編程)特性,可以很方便的對用戶的業(yè)務(wù)代碼進(jìn)行橫向抽取,根據(jù)具體業(yè)務(wù)需求對應(yīng)用功能進(jìn)行增強(qiáng)。
在SpringBoot中使用Interceptor,同時(shí)采用全注解開發(fā),涉及到以下接口和類:
- HandlerInterceptor:處理器攔截器,handler就是處理器,在springboot web開發(fā)中,由控制器來處理web請求,因此handler具體指控制器
- 使用全注解開發(fā),通過@Configuration注解,讓一個(gè)java對象主任到IOC容器,并作為配置對象,這里的JavaConfig類相當(dāng)于一個(gè)xml配置文件;
- 在以前的xml配置中
(1)通過引入一些標(biāo)簽進(jìn)行配置,在JavaConfig中,通過繼承一個(gè)類或者實(shí)現(xiàn)一個(gè)接口來實(shí)現(xiàn)配置,這里所繼承的類、所實(shí)現(xiàn)的接口就相當(dāng)于引入的標(biāo)簽;
(3)通過設(shè)置所引入標(biāo)簽的屬性和值,可以實(shí)現(xiàn)個(gè)性化配置,在JavaConfig中通過覆蓋類或者接口的方法來實(shí)現(xiàn)個(gè)性化配置。
下面通過一個(gè)案例來實(shí)現(xiàn)自定義攔截器
攔截/user/開頭的請求,不攔截/usr/login請求
1. 定義攔截器
package cn.eis220.web;
import org.springframework.web.servlet.HandlerInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("執(zhí)行了logininterceptor的preHandle方法");
return true;
}
}2. 使用JavaConfig注冊攔截器
java配置類相當(dāng)于xml配置文件
xml中通過引入interceptor標(biāo)簽來進(jìn)行配置,java配置類通過實(shí)現(xiàn)WebMvcController進(jìn)行配置;
xml中通過修改標(biāo)簽的屬性和值來個(gè)性化配置,java配置類通過實(shí)現(xiàn)WebMvcController的方法進(jìn)行個(gè)性化配置
package cn.eis220.config;
import cn.eis220.web.LoginInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class MyAppCofnig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
LoginInterceptor loginInterceptor = new LoginInterceptor();
String[] path = {"/user/**"};
String[] excludePath = {"/user/login"};
registry.addInterceptor(loginInterceptor).addPathPatterns(path).excludePathPatterns(excludePath);
}
}3. 定義控制器,測試攔截器
package cn.eis220.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class BootController {
@RequestMapping("/user/account")
@ResponseBody
public String userAccount(){
return "/user/account";
}
@RequestMapping("/user/login")
@ResponseBody
public String userLogin(){
return "/user/login";
}
}4. 總結(jié)
步驟:
- 如何定義自己的攔截器:
實(shí)現(xiàn)HandlerInterceptor接口的方法,來自定義攔截器
- 如何注冊攔截器:
JavaConfig配置類實(shí)現(xiàn)WebMvcConfigurer接口的addInterceptor方法來注冊攔截器
到此這篇關(guān)于在springboot中使用攔截器的文章就介紹到這了,更多相關(guān)springboot使用攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringSecurity實(shí)現(xiàn)自定義用戶認(rèn)證方案
Spring?Security?實(shí)現(xiàn)自定義用戶認(rèn)證方案可以根據(jù)具體需求和業(yè)務(wù)場景進(jìn)行設(shè)計(jì)和實(shí)施,滿足不同的安全需求和業(yè)務(wù)需求,這種靈活性使得認(rèn)證機(jī)制能夠更好地適應(yīng)各種復(fù)雜的環(huán)境和變化?,本文給大家介紹了SpringSecurity實(shí)現(xiàn)自定義用戶認(rèn)證方案,需要的朋友可以參考下2025-01-01
阿里面試Nacos配置中心交互模型是push還是pull原理解析
這篇文章主要為大家介紹了阿里面試Nacos配置中心交互模型是push還是pull原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
Spring @ExceptionHandler注解統(tǒng)一異常處理和獲取方法名
這篇文章主要介紹了Spring注解之@ExceptionHandler 統(tǒng)一異常處理和獲取方法名,在實(shí)際項(xiàng)目中,合理使用@ExceptionHandler能夠提高代碼的可維護(hù)性和用戶體驗(yàn),通過本文的解析和實(shí)踐,讀者可以更好地理解和掌握@ExceptionHandler的用法和原理2023-09-09
Spring?Boot如何監(jiān)控SQL運(yùn)行情況?
Druid是Java語言中最好的數(shù)據(jù)庫連接池,下面這篇文章主要給大家介紹了關(guān)于Spring?Boot如何監(jiān)控SQL運(yùn)行情況的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
Java注解機(jī)制之Spring自動(dòng)裝配實(shí)現(xiàn)原理詳解
這篇文章主要為大家詳細(xì)介紹了Java注解機(jī)制之Spring自動(dòng)裝配實(shí)現(xiàn)原理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
JAVA?DOC如何生成標(biāo)準(zhǔn)的JAVA?API文檔詳解
這篇文章主要給大家介紹了關(guān)于JAVA?DOC如何生成標(biāo)準(zhǔn)的JAVA?API文檔的相關(guān)資料,Javadoc是Sun公司提供的一種工具,它可以從程序源代碼中抽取類、方法、成員等注釋,然后形成一個(gè)和源代碼配套的API幫助文檔,需要的朋友可以參考下2024-06-06

