SpringBoot使用Sa-Token實(shí)現(xiàn)路徑攔截和特定接口放行
1. 引入依賴
首先,在pom.xml文件中引入Sa-Token相關(guān)的依賴。Sa-Token是一個(gè)輕量級(jí)的Java權(quán)限認(rèn)證框架,可以幫助我們輕松實(shí)現(xiàn)用戶登錄狀態(tài)的管理和權(quán)限認(rèn)證。
<dependency>
<groupId>cn.dev33</groupId>
<artifactId>sa-token-spring-boot-starter</artifactId>
<version>1.27.0</version>
</dependency>
2. 創(chuàng)建配置類 SecurityProperties
定義一個(gè)配置類SecurityProperties,用于讀取和存儲(chǔ)從配置文件中加載的排除路徑信息。這里使用了Spring Boot的@ConfigurationProperties注解來綁定配置文件中的屬性。
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import lombok.Data;
@Data
@Component
@ConfigurationProperties(prefix = "security")
public class SecurityProperties {
/**
* 排除路徑
*/
private String[] excludes;
}
@Data:這是Lombok的注解,自動(dòng)生成getter和setter方法。@Component:將該類注冊(cè)為Spring的組件。@ConfigurationProperties:指定前綴security,從配置文件中讀取以該前綴開頭的屬性,并將這些屬性映射到該類的字段上。
3. 編寫配置文件
在配置文件application.yml或者application.properties中,配置需要排除的路徑。例如:
application.yml:
security:
excludes:
- "/public/**"
- "/login"
- "/register"
application.properties:
security.excludes=/public/**,/login,/register
/public/**:排除所有以/public/開頭的路徑。/login:排除/login路徑。/register:排除/register路徑。
4. 配置攔截器
創(chuàng)建一個(gè)配置類WebConfig,實(shí)現(xiàn)WebMvcConfigurer接口,在其中配置Sa-Token的攔截器,并將排除的路徑應(yīng)用到攔截器中。
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import cn.dev33.satoken.interceptor.SaInterceptor;
import cn.dev33.satoken.router.SaRouter;
import cn.dev33.satoken.stp.StpUtil;
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Autowired
private SecurityProperties securityProperties;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new SaInterceptor(handler -> {
// 獲取所有的URL并進(jìn)行檢查
SaRouter.match("/**").check(() -> {
// 檢查是否登錄
StpUtil.checkLogin();
});
}))
.addPathPatterns("/**") // 攔截所有路徑
.excludePathPatterns(securityProperties.getExcludes()); // 排除指定路徑
}
}
@Configuration:標(biāo)識(shí)這是一個(gè)配置類。addInterceptors:重寫該方法,向Spring的攔截器注冊(cè)中心添加自定義的攔截器。SaInterceptor:Sa-Token提供的攔截器,主要用于權(quán)限驗(yàn)證。SaRouter.match("/**"):匹配所有路徑。StpUtil.checkLogin():Sa-Token提供的登錄狀態(tài)檢查方法,用于驗(yàn)證用戶是否已登錄。excludePathPatterns:從攔截中排除指定的路徑,這些路徑從SecurityProperties中獲取。
5. 驗(yàn)證攔截效果
啟動(dòng)Spring Boot應(yīng)用程序,驗(yàn)證配置是否生效。以下是一些測試步驟:
訪問排除路徑:
- 嘗試訪問配置文件中排除的路徑,如
/public/**、/login、/register。 - 這些路徑應(yīng)不會(huì)觸發(fā)登錄檢查,可以直接訪問。
- 嘗試訪問配置文件中排除的路徑,如
訪問其他路徑:
- 嘗試訪問其他未排除的路徑,如
/admin、/user/profile等。 - 這些路徑應(yīng)觸發(fā)Sa-Token的登錄驗(yàn)證邏輯,如果用戶未登錄,將會(huì)被攔截,并返回相應(yīng)的未登錄提示。
- 嘗試訪問其他未排除的路徑,如
代碼解析
SecurityProperties類:通過@ConfigurationProperties注解,Spring Boot會(huì)自動(dòng)將前綴為security的配置屬性綁定到該類的excludes字段上,從而實(shí)現(xiàn)排除路徑的配置。- 配置文件:在配置文件中定義需要排除的路徑,以便動(dòng)態(tài)加載到
SecurityProperties中。 WebConfig類:實(shí)現(xiàn)WebMvcConfigurer接口,通過addInterceptors方法添加Sa-Token的攔截器,并使用excludePathPatterns方法將配置文件中定義的排除路徑應(yīng)用到攔截器中。
詳細(xì)解釋
依賴配置
Sa-Token是一個(gè)輕量級(jí)的權(quán)限認(rèn)證框架,可以幫助我們輕松實(shí)現(xiàn)用戶登錄狀態(tài)的管理和權(quán)限認(rèn)證。通過引入sa-token-spring-boot-starter依賴,我們可以很方便地將其集成到Spring Boot項(xiàng)目中。
配置類 SecurityProperties
SecurityProperties類的作用是將配置文件中定義的排除路徑讀取并存儲(chǔ)到excludes數(shù)組中。通過使用@ConfigurationProperties注解,我們可以將前綴為security的屬性綁定到該類的excludes字段上。這樣做的好處是,排除路徑可以通過配置文件進(jìn)行動(dòng)態(tài)配置,方便管理和維護(hù)。
配置文件
在配置文件中,我們定義了需要排除的路徑。這些路徑將不會(huì)被攔截器攔截,可以直接訪問。配置文件支持YAML格式和Properties格式,根據(jù)項(xiàng)目需要選擇合適的格式進(jìn)行配置。
攔截器配置
在WebConfig類中,我們實(shí)現(xiàn)了WebMvcConfigurer接口,并重寫了addInterceptors方法。在該方法中,我們創(chuàng)建了一個(gè)Sa-Token的攔截器,并通過SaRouter.match("/**")匹配所有路徑。對(duì)于匹配到的路徑,我們使用StpUtil.checkLogin()方法進(jìn)行登錄狀態(tài)檢查。如果用戶未登錄,將會(huì)被攔截,并返回相應(yīng)的未登錄提示。
通過excludePathPatterns方法,我們將從SecurityProperties中獲取的排除路徑應(yīng)用到攔截器中。這樣一來,配置文件中定義的排除路徑將不會(huì)被攔截器攔截,可以直接訪問。
總結(jié)
通過本文的介紹,我們了解了如何在Spring Boot中使用Sa-Token實(shí)現(xiàn)路徑攔截和特定接口放行。我們首先引入了Sa-Token的依賴,然后定義了一個(gè)配置類SecurityProperties,用于讀取和存儲(chǔ)排除路徑信息。接著,在配置文件中定義了需要排除的路徑,并在WebConfig類中配置了Sa-Token的攔截器,將排除路徑應(yīng)用到攔截器中。最后,通過測試和驗(yàn)證,確保配置生效,實(shí)現(xiàn)了對(duì)特定路徑的放行和其他路徑的權(quán)限驗(yàn)證。
這種方式可以幫助開發(fā)者更靈活地管理Web應(yīng)用中的訪問控制,提升系統(tǒng)的安全性和可維護(hù)性。如果你有更多的自定義需求,可以根據(jù)Sa-Token的文檔進(jìn)行進(jìn)一步配置和擴(kuò)展。
以上就是SpringBoot使用Sa-Token實(shí)現(xiàn)路徑攔截和特定接口放行的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Sa-Token攔截和放行的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
遞歸出現(xiàn)棧溢出stackoverflow的問題及解決
這篇文章主要介紹了關(guān)于遞歸出現(xiàn)棧溢出stackoverflow的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
mybatisplus如何在xml的連表查詢中使用queryWrapper
這篇文章主要介紹了mybatisplus如何在xml的連表查詢中使用queryWrapper,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
java和javascript中過濾掉img形式的字符串不顯示圖片的方法
這篇文章主要介紹了java和javascript中過濾掉img形式的字符串不顯示圖片的方法,以實(shí)例形式分別講述了采用java和javascript實(shí)現(xiàn)過濾掉img形式字符串的技巧,需要的朋友可以參考下2015-02-02
IDEA maven項(xiàng)目中刷新依賴的兩種方法小結(jié)
這篇文章主要介紹了IDEA maven項(xiàng)目中刷新依賴的兩種方法小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
Springboot項(xiàng)目快速實(shí)現(xiàn)Aop功能
這篇文章主要介紹了Springboot項(xiàng)目如何快速實(shí)現(xiàn)Aop功能,對(duì)此方面感興趣的小伙伴可以詳細(xì)參考閱讀本文,本文有一定的參考價(jià)值2023-03-03

