Spring Security表單配置過程分步講解
Spring Security授權(quán)
實現(xiàn)授權(quán)接口方法安全注解
實現(xiàn)授權(quán)接口
實現(xiàn)接口
org.springframework.security.authorization.AuthorizationManager
import org.springframework.security.authorization.AuthorizationDecision;
import org.springframework.security.authorization.AuthorizationManager;
import org.springframework.security.core.Authentication;
import org.springframework.security.web.access.intercept.RequestAuthorizationContext;
import java.util.function.Supplier;
public class MyAuthorizationManager implements AuthorizationManager<RequestAuthorizationContext> {
@Override
public AuthorizationDecision check(Supplier<Authentication> authentication, RequestAuthorizationContext object) {
// ... 這里可以寫授權(quán)邏輯
// 返回true表示有權(quán)限
return new AuthorizationDecision(true);
}
}
然后在配置中加入
@Bean
public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
http.formLogin(form -> {
form
.loginProcessingUrl("/login") // 接受登錄請求的url,默認也是login
.loginPage("/toLogin") // 表單對應的url
.successForwardUrl("/success") // 登錄成功后重定向的url
.failureForwardUrl("/failure") // 登錄失敗后重定向的url
;
})
.authorizeHttpRequests(authorize -> {
// 授權(quán)所有請求都得經(jīng)過授權(quán)
authorize.anyRequest().access(new MyAuthorizationManager());
})
.csrf().disable(); // 簡單粗暴禁用csrf
return http.build();
}
授權(quán)配置完成
方法安全注解
首先開啟方法安全注解
@Configuration
@EnableWebSecurity
@EnableMethodSecurity
public class SecurityConfig {
// ... 省略配置
}
方法安全注解常用的有兩個
org.springframework.security.access.prepost.PreAuthorize
org.springframework.security.access.prepost.PostAuthorize
PreAuthorize 是訪問前授權(quán)
PostAuthorize 是訪問后授權(quán)
例子:
import org.springframework.security.access.prepost.PostAuthorize;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import security.demo.DataEntity;
import java.util.UUID;
@RestController
@RequestMapping("/admin")
public class AdminController {
@GetMapping("/res/{id}")
@PreAuthorize("hasAnyRole('admin')")
public String getResById(@PathVariable("id") String id) {
return id;
}
@GetMapping("/res/{id}")
@PreAuthorize("hasAnyRole('admin')")
@PostAuthorize("returnObject.creator == authentication.name")
public DataEntity getDataEntityById(@PathVariable("id") String id) {
String creator = UUID.randomUUID().toString();
return DataEntity.builder().id(id).someData("一些數(shù)據(jù)").creator(creator).build();
}
}
其中的DataEntity是一個簡單的pojo類
import lombok.Builder;
import lombok.Data;
@Data
@Builder
public class DataEntity {
private String id;
private String someData;
private String creator;
}
PreAuthorize 里面可以接收授權(quán)表達式,例子的意思是,當前用戶要有admin角色
PostAuthorize 也接收授權(quán)表達式,例子里面的意思是,然后的實體類的creator屬性必須是當前用戶的username
更多的表達式可以參考官方文檔: https://docs.spring.io/spring-security/reference/5.7/servlet/authorization/expression-based.html
官方文檔里面有更多的注解和更多的使用方式
到此這篇關(guān)于Spring Security表單配置過程分步講解的文章就介紹到這了,更多相關(guān)Spring Security表單配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis的mapper特殊字符轉(zhuǎn)移及動態(tài)SQL條件查詢小結(jié)
mybatis mapper文件中條件查詢符,如>=,<,之類是不能直接寫的會報錯的需要轉(zhuǎn)移一下,本文給大家介紹了常見的條件查詢操作,對mybatis的mapper特殊字符及動態(tài)SQL條件查詢相關(guān)知識感興趣的朋友一起看看吧2021-09-09
Spring Data MongoDB 數(shù)據(jù)庫批量操作的方法
在項目開發(fā)中經(jīng)常會批量插入數(shù)據(jù)和更新數(shù)據(jù)的操作,這篇文章主要介紹了Spring Data MongoDB 數(shù)據(jù)庫批量操作的方法,非常具有實用價值,需要的朋友可以參考下2018-11-11
Spring應用拋出NoUniqueBeanDefinitionException異常的解決方案
這篇文章介紹了解決org.springframework.beans.factory.NoUniqueBeanDefinitionException異常的一些解決方案,從這些解決方案可以看出Spring框架的設(shè)計精妙,遇見此問題的朋友可以參考下該解決方案2021-06-06
java優(yōu)先隊列PriorityQueue中Comparator的用法詳解
這篇文章主要介紹了java優(yōu)先隊列PriorityQueue中Comparator的用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02
Java創(chuàng)建多線程異步執(zhí)行實現(xiàn)代碼解析
這篇文章主要介紹了Java創(chuàng)建多線程異步執(zhí)行實現(xiàn)代碼解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07
通過JDBC連接oracle數(shù)據(jù)庫的十大技巧
通過JDBC連接oracle數(shù)據(jù)庫的十大技巧...2006-12-12

