以前胖哥說(shuō)過(guò)SecurityConfigurerAdapter會(huì)在即將發(fā)布的5.7版本作廢,從Spring Security 5.4版本開始會(huì)提供一個(gè)原型范圍的??HttpSecurity?
??來(lái)幫助我們構(gòu)建過(guò)濾器鏈??SecurityFilterChain?
?:
@Bean(HTTPSECURITY_BEAN_NAME)
@Scope("prototype")
HttpSecurity httpSecurity() throws Exception {
WebSecurityConfigurerAdapter.LazyPasswordEncoder passwordEncoder = new WebSecurityConfigurerAdapter.LazyPasswordEncoder(
this.context);
AuthenticationManagerBuilder authenticationBuilder = new WebSecurityConfigurerAdapter.DefaultPasswordEncoderAuthenticationManagerBuilder(
this.objectPostProcessor, passwordEncoder);
authenticationBuilder.parentAuthenticationManager(authenticationManager());
HttpSecurity http = new HttpSecurity(this.objectPostProcessor, authenticationBuilder, createSharedObjects());
// @formatter:off
http
.csrf(withDefaults())
.addFilter(new WebAsyncManagerIntegrationFilter())
.exceptionHandling(withDefaults())
.headers(withDefaults())
.sessionManagement(withDefaults())
.securityContext(withDefaults())
.requestCache(withDefaults())
.anonymous(withDefaults())
.servletApi(withDefaults())
.apply(new DefaultLoginPageConfigurer<>());
http.logout(withDefaults());
// @formatter:on
return http;
}
這里會(huì)構(gòu)建基于原型的??HttpSecurity?
?Bean,并且初始化了一些默認(rèn)配置供我們來(lái)使用。涉及Spring Security的日常開發(fā)都是圍繞這個(gè)類進(jìn)行的,所以這個(gè)類是學(xué)習(xí)Spring Security的重中之重。
?
基于原型(?
?prototype?
?)的Spring Bean的一個(gè)典型應(yīng)用場(chǎng)景,
基本配置
日常我們使用的一些配置項(xiàng)如下:
方法 | 說(shuō)明 |
requestMatchers() | 為? |
openidLogin() | 用于基于 ? |
headers() | 將安全標(biāo)頭添加到響應(yīng),比如說(shuō)簡(jiǎn)單的 XSS 保護(hù) |
cors() | 配置跨域資源共享( CORS ) |
sessionManagement() | 配置會(huì)話管理 |
portMapper() | 配置一個(gè)? |
jee() | 配置基于容器的預(yù)認(rèn)證。在這種情況下,認(rèn)證由Servlet容器管理 |
x509() | 配置基于x509的預(yù)認(rèn)證 |
rememberMe | 配置“記住我”的驗(yàn)證 |
authorizeRequests() | 基于使用? |
requestCache() | 配置請(qǐng)求緩存 |
exceptionHandling() | 配置錯(cuò)誤處理 |
securityContext() | 在? |
servletApi() | 將? |
csrf() | 添加 CSRF 支持,使用? |
logout() | 添加退出登錄支持。當(dāng)使用? |
anonymous() | 配置匿名用戶的表示方法。當(dāng)與? |
authenticationManager() | 配置? |
authenticationProvider() | 添加? |
formLogin() | 指定支持基于表單的身份驗(yàn)證。如果未指定? |
oauth2Login() | 根據(jù)外部OAuth 2.0或OpenID Connect 1.0提供程序配置身份驗(yàn)證 |
oauth2Client() | OAuth2.0 客戶端相關(guān)的配置 |
oauth2ResourceServer() | OAuth2.0資源服務(wù)器相關(guān)的配置 |
requiresChannel() | 配置通道安全。為了使該配置有用,必須提供至少一個(gè)到所需信道的映射 |
httpBasic() | 配置 Http Basic 驗(yàn)證 |
addFilter() | 添加一個(gè)已經(jīng)在內(nèi)置過(guò)濾器注冊(cè)表注冊(cè)過(guò)的過(guò)濾器實(shí)例或者子類 |
addFilterBefore() | 在指定的Filter類之前添加過(guò)濾器 |
addFilterAt() | 在指定的Filter類的位置添加過(guò)濾器 |
addFilterAfter() | 在指定的Filter類的之后添加過(guò)濾器 |
and() | 連接以上策略的連接器,用來(lái)組合安全策略。實(shí)際上就是”而且”的意思 |
高級(jí)玩法
新手建議先把上面的基本玩法有選擇的弄明白,然后有精力的話去研究下??HttpSecurity?
?的高級(jí)玩法。
apply
這個(gè)方法用來(lái)把其它的一些配置合并到當(dāng)前的配置中去,形成插件化,支持??SecurityConfigurerAdapter?
??或者??SecurityConfigurer?
??的實(shí)現(xiàn)。其實(shí)內(nèi)置的一些配置都是以這種形式集成到??HttpSecurity?
?中去的。例如文章開頭的配置中有默認(rèn)登錄頁(yè)面相關(guān)的配置:
httpSecurity.apply(new DefaultLoginPageConfigurer<>());
胖哥就利用這個(gè)搞了一個(gè)支持小程序登錄和驗(yàn)證碼登錄的擴(kuò)展?
spring-security-login-extension
objectPostProcessor
配置一個(gè)自定義??ObjectPostProcessor?
??。??ObjectPostProcessor?
?可以改變某些配置內(nèi)部的機(jī)制,這些配置往往不直接對(duì)外提供操作接口。
獲取、移除配置類
??getConfigurer?
??用來(lái)獲取已經(jīng)??apply?
??的配置類;??getConfigurers?
??用來(lái)獲取已經(jīng)??apply?
?某個(gè)類型的所有配置類。這個(gè)現(xiàn)在是我最喜歡的自定義的方式。
配置、獲取SharedObject
??SharedObject?
??是在配置中進(jìn)行共享的一些對(duì)象,HttpSecurity共享了一些非常有用的對(duì)象可以供各個(gè)配置之間共享,比如??AuthenticationManager?
??。相關(guān)的方法有??setSharedObject?
??、??getSharedObject?
??、??getSharedObjects?
?。
獲取SecurityFilterChain
??HttpSecurity?
??也提供了構(gòu)建目標(biāo)對(duì)象??SecurityFilterChain?
??的實(shí)例的方法。你可以通過(guò)??build()?
??來(lái)對(duì)配置進(jìn)行初次構(gòu)建;也可以通過(guò)??getObject()?
??來(lái)獲取已經(jīng)構(gòu)建的實(shí)例;甚至你可以使用??getOrBuild()?
?來(lái)進(jìn)行直接獲取實(shí)例或者構(gòu)建實(shí)例。
所以新的配置都是這樣的:
@Bean
SecurityFilterChain securityFilterChain (HttpSecurity http) {
http.cors();
return http.build();
}
?
記住每一個(gè)?
?HttpSecurity?
?只能被構(gòu)建成功一次。
這一篇非常重要
本篇東西非常重要,不是馬上就能掌握的,需要有些耐心,需要在使用和學(xué)習(xí)中總結(jié)和發(fā)現(xiàn)。
另外最近胖哥有很多成系列的內(nèi)容輸出:
OAuth2?系列教程
- 開源了一個(gè)登錄組件擴(kuò)展spring-security-login-extension,降低對(duì)接配置成本。
- 粉絲福利:正版IntelliJ IDEA?抽獎(jiǎng)
有興趣的可以看看。
本文摘自 :https://blog.51cto.com/u