Spring Security 認證與授權實現機制


Spring Security 是一個功能強大且高度可定制的身份驗證和訪問控制框架,其認證和授權實現機制如下:

一、認證(Authentication)實現
1. 核心組件
AuthenticationManager:認證入口點,委托給AuthenticationProvider

AuthenticationProvider:實際執行認證邏輯

UserDetailsService:加載用戶特定數據

SecurityContextHolder:存儲當前安全上下文

2. 認證流程
用戶提交憑證(用戶名/密碼等)

UsernamePasswordAuthenticationFilter攔截請求,創建Authentication對象

ProviderManager選擇合適的AuthenticationProvider

DaoAuthenticationProvider調用UserDetailsService加載用戶詳情

PasswordEncoder驗證密碼

認證成功后構建完全填充的Authentication對象

將Authentication存入SecurityContext

3. 常用認證方式

@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {

@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
// 內存認證
auth.inMemoryAuthentication()
.withUser("user").password(passwordEncoder().encode("password")).roles("USER");

// JDBC認證
auth.jdbcAuthentication()
.dataSource(dataSource)
.usersByUsernameQuery("select username,password,enabled from users where username=?")
.authoritiesByUsernameQuery("select username,authority from authorities where username=?");

// 自定義UserDetailsService
auth.userDetailsService(customUserDetailsService)
.passwordEncoder(passwordEncoder());
}

@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
二、授權(Authorization)實現
1. 核心概念
GrantedAuthority:授予用戶的權限(如角色)

ConfigAttribute:訪問資源所需的權限

AccessDecisionManager:做出最終的訪問控制決策

AccessDecisionVoter:投票決定是否授予訪問權限

2. 授權流程
FilterSecurityInterceptor攔截請求

獲取請求資源的配置屬性(所需權限)

AccessDecisionManager收集投票

基于投票結果允許/拒絕訪問

3. 授權配置方式

@Override
protected void configure(HttpSecurity http) throws Exception {
http
.authorizeRequests()
.antMatchers("/admin/**").hasRole("ADMIN") // 基于角色
.antMatchers("/api/**").hasAuthority("API_ACCESS") // 基于權限
.antMatchers("/public/**").permitAll() // 公開訪問
.anyRequest().authenticated() // 其他請求需要認證
.and()
.formLogin() // 表單登錄
.and()
.httpBasic(); // HTTP基本認證
}
三、高級特性
1. 方法級安全


@PreAuthorize("hasRole('ADMIN') or #user.username == authentication.name")
public void updateUser(User user) {
// ...
}

@PostAuthorize("returnObject.owner == authentication.name")
public Document getDocument(Long id) {
// ...
}

@Secured("ROLE_ADMIN")
public void adminOperation() {
// ...
}
2. 自定義認證邏輯

@Component
public class CustomAuthenticationProvider implements AuthenticationProvider {

? ? @Autowired
private CustomUserDetailsService userDetailsService;

@Autowired
private PasswordEncoder passwordEncoder;

? ? @Override
public Authentication authenticate(Authentication authentication)?
throws AuthenticationException {

String username = authentication.getName();
String password = authentication.getCredentials().toString();

CustomUser user = userDetailsService.loadUserByUsername(username);

if (passwordEncoder.matches(password, user.getPassword())) {
return new UsernamePasswordAuthenticationToken(
user, password, user.getAuthorities());
} else {
throw new BadCredentialsException("Authentication failed");
}
}

? ? @Override
public boolean supports(Class<?> authentication) {
return authentication.equals(UsernamePasswordAuthenticationToken.class);
}
}
3. OAuth2集成


@Configuration
@EnableAuthorizationServer
public class OAuth2Config extends AuthorizationServerConfigurerAdapter {

@Override
public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
clients.inMemory()
.withClient("client")
.secret(passwordEncoder.encode("secret"))
.authorizedGrantTypes("authorization_code", "refresh_token")
.scopes("read", "write")
.redirectUris("http://localhost:8080/login/oauth2/code/custom");
}
}
四、實際應用建議
密碼安全:始終使用強密碼編碼器(如BCrypt)

CSRF防護:生產環境必須啟用

會話管理:合理配置會話固定保護和并發控制

CORS配置:根據實際需求精細控制

安全頭部:啟用XSS保護、HSTS等安全頭部

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/94322.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/94322.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/94322.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

開源的時間跟蹤工具TimeTagger

簡介 什么是 TimeTagger &#xff1f; TimeTagger 是一個開源的時間跟蹤工具&#xff0c;旨在幫助用戶記錄和分析他們的時間使用情況。它提供了一個互動的用戶界面和強大的報告功能&#xff0c;適合個人和自由職業者使用。 主要特點 直觀的用戶界面&#xff1a;基于互動時間線…

學習游戲制作記錄(角色屬性和狀態腳本)8.4

1.實現簡單的角色屬性創建CharactorState腳本&#xff1a;掛載在敵人和玩家身上public float damage;//角色傷害public float maxHp;//最大生命[SerializeField] private float currentHealth;//當前生命void Start(){currentHealth maxHp;//初始化將當前生命設置為最大生命}p…

04-Chapter02-Example01

文章介紹 1、完善項目結構 1.1 新建第二章對應模塊Chapter021.2 新建模塊Chapter02對應包com.itheima1.3 在包com.itheima下新建class類 &#xff0c;類名稱Example01.java項目結構如下&#xff1a;2、編寫Example01.java代碼 P38 package com.itheima;public class Example01…

【達夢MPP(帶主備)集群搭建】

達夢MPP&#xff08;帶主備&#xff09;集群搭建 為了提高MPP系統可靠性&#xff0c;克服由于單節點故障導致整個系統不能繼續正常工作的問題&#xff0c;DM在普通的MPP系統基礎上&#xff0c;引入數據守護主備機制&#xff0c;為每一個MPP節點配置一個實時備庫作為備份節點&a…

Java基礎學習(一):類名規范、返回值、注釋、數據類型

目錄 一、類名規范二、返回值三、注釋四、數據類型 1. 基本類型2. 引用類型3. 強制數據類型轉換4. 進制5. 進制的轉換6. 超范圍運算 相關文章 Java基礎學習&#xff08;二&#xff09;&#xff1a;Java中的變量和常量、final&#xff08;重點&#xff09;、運算、字符串 了…

Nginx相關實驗(2)

nginx的一些高級配置 nginx狀態頁 基于nginx 模塊 ngx_http_stub_status_module 實現&#xff0c; 在編譯安裝nginx的時候需要添加編譯參數 --with-http_stub_status_module 否則配置完成之后監測會是提示語法錯誤 #檢查模塊是否配置 如果不存在需要添加模塊重新編譯 nginx …

2.Java和C++有什么區別

2.Java和C有什么區別 1.在C中&#xff0c;支持操作符重載&#xff0c;而在Java里是不允許的 2.C支持多繼承&#xff0c;而Java不可以&#xff0c;但Java可以單繼承多實現 3.Java內置多線程機制&#xff0c;而C沒有 4.Java里面自帶了垃圾回收機制&#xff0c;可以自動清理緩存等…

MLIR Introduction

簡介 MLIR 項目是一個構建可重用和可擴展編譯器基礎設施創新項目&#xff0c;旨在解決軟件碎片化問題&#xff0c;顯著降低構建特定領域編譯器的成本。 基于MLIR&#xff0c;可以實現&#xff1a; 數據流圖表達&#xff08;如TensorFlow&#xff09;&#xff0c;包含dynamic…

[找出字符串中第一個匹配項的下標]

代碼思路分析&#xff1a; 1. 邊界情況處理 代碼中沒有顯式處理以下邊界情況&#xff0c;但邏輯已隱含支持&#xff1a; needle 為空字符串&#xff1a;應返回 0&#xff08;但題目通常保證 needle 非空&#xff09;。haystack 比 needle 短&#xff1a;直接返回 -1&#xff08…

深入剖析RT-Thread串口驅動:基于STM32H750的FinSH Shell全鏈路Trace分析與實戰解密(上)

0. 概述 這是cherryusb代碼trace分析系列文章之七。 RT-Thread串口驅動框架與FinSH Shell運行機制深度解析&#xff1a;針對STM32H750 ART-PI平臺&#xff0c;本文獨辟蹊徑采用創新的代碼trace分析方法&#xff0c;破解龐大串口框架下的復雜運行邏輯。通過精確trace日志與drv_u…

Python與C++通信教程:C++打包dll,供Python調用(1)

目錄 1,新建一個工程 math_functions.cpp內容: 先編譯一下看是否可以正常運行: 2,編譯成dll,并用Python調用 有兩種方式: 命令 1(使用靜態鏈接): 可移植性: 命令 2(動態鏈接): 可移植性: 這里我使用的是靜態鏈接的方式: python調用實例 test_dll.py 1,…

編程與數學 03-002 計算機網絡 19_網絡新技術研究

編程與數學 03-002 計算機網絡 19_網絡新技術研究一、軟件定義網絡&#xff08;SDN&#xff09;&#xff08;一&#xff09;SDN的基本原理與架構&#xff08;二&#xff09;SDN的應用場景與優勢二、網絡功能虛擬化&#xff08;NFV&#xff09;&#xff08;一&#xff09;NFV的概…

uniapp 跨端開發

一、創建uniapp項目 1. 項目架構2. 初始化項目3. pages.json 和 tabBar 案例4. uni-app和原生小程序開發區別5. 用命令行創建uni-app項目 官網鏈接&#xff1a;https://uniapp.dcloud.net.cn/quickstart-cli.html#創建uni-app6. 用vscode開發uni-app在uni-app中只有manifest.js…

區塊鏈支付技術的核心原理

區塊鏈支付利用分布式賬本技術&#xff08;DLT&#xff09;實現點對點的價值轉移&#xff0c;無需傳統銀行或支付網關的中介。核心特點是去中心化、透明、可追溯。? 基本流程&#xff1a;1. 用戶發起交易&#xff1a;通過加密貨幣錢包發送支付請求&#xff08;例如用ETH支付&a…

linux中 多進程 導致cuda錯誤的問題解決

問題總結與解決方案 核心問題 在使用 Linux 系統時&#xff0c;多進程并行計算中加載模型到 GPU 時出現錯誤&#xff1a;_MODEL SentenceTransformer( model_path, device "cuda" if torch.cuda.is_available() else "cpu" )根本原因&#xff1a; CUDA 上…

智能感知的新入口:AIGC 與低延遲視頻通路的深度融合

?? 引言&#xff1a;AIGC&#xff0c;正在重構視覺智能的“生成邏輯” AI生成內容&#xff08;AIGC&#xff09;正在從“內容創作工具”躍升為計算機視覺系統的新引擎。它不再只是“文生圖”、“圖生文”的演示技術&#xff0c;而是實實在在地改變著我們構建、處理和理解視覺…

Ubuntu 內網多臺服務器時間同步方案(適用于臨時能上外網的環境)

哎&#xff0c;最近項目是運行在內網環境下的&#xff0c;出現了由于時間不同步導致的bug。一般來講&#xff0c;幾臺服務器的時間不一致&#xff0c;會帶來很多問題&#xff0c;比如日志時間對不上、分布式服務出現異常&#xff0c;等等。項目上現在有三臺服務器&#xff0c;其…

延長電池壽命的低Iq技術

本文章是筆者整理的備忘筆記。希望在幫助自己溫習避免遺忘的同時&#xff0c;也能幫助其他需要參考的朋友。如有謬誤&#xff0c;歡迎大家進行指正。一、概述隨著電池供電型應用的激增&#xff0c;人們對質優價廉的電池和電池包的需求持續猛漲。電池制造商們不斷采用新的化學物…

QT 如何實現enum與字符串的互轉

將enum中定義的枚舉值&#xff0c;以字符串的形式寫入文件&#xff0c;同時也能從字符串轉為枚舉值。舉例說明&#xff1a; ColorSelector中的Colors枚舉&#xff0c;我們希望 kColorRed 這個寫入到本地文件時&#xff0c;可以直接保存“kColorRed”&#xff0c;而非kColorRed對…

SLAM卷不動了,機器人還有哪些方向能做?

關注gongzhonghao【CVPR頂會精選】眾所周知&#xff0c;機器人因復雜環境適應性差、硬件部署成本高&#xff0c;對高效泛化一直需求迫切。再加上多傳感器協同難題、真實場景數據獲取不易&#xff0c;當下對遷移學習 機器人智能融合的研究也就更熱烈了。不過顯然&#xff0c;這…