版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第8章SpringBoot的安全控制學(xué)習(xí)目的與要求本章首先重點講解SpringSecurity安全控制機(jī)制,然后介紹SpringBootSecurity操作實例。通過本章的學(xué)習(xí),掌握如何使用SpringSecurity安全控制機(jī)制解決企業(yè)應(yīng)用程序的安全問題。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
目錄8.1SpringSecurity快速入門8.2SpringBoot的支持8.3實際開發(fā)中的SpringSecurity操作實例《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.1.1什么是SpringSecuritySpringSecurity是一個專門針對Sping應(yīng)用系統(tǒng)的安全框架,充分利用了Spring框架的依賴注入和AOP功能,為Spring應(yīng)用系統(tǒng)提供安全訪問控制解決方案。在SpringSecurity安全框架中,有兩個重要概念,即授權(quán)(Authorization)和認(rèn)證(Authentication)。授權(quán)即確定用戶在當(dāng)前應(yīng)用系統(tǒng)下所擁有的功能權(quán)限;認(rèn)證即確認(rèn)用戶訪問當(dāng)前系統(tǒng)的身份?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.1.2SpringSecurity的用戶認(rèn)證在SpringSecurity安全框架中,可以通過配置AuthenticationManager認(rèn)證管理器完成用戶認(rèn)證。示例代碼如下:@BeanpublicAuthenticationManagerauthenticationManager(AuthenticationConfigurationauthenticationConfiguration)throwsException{returnauthenticationConfiguration.getAuthenticationManager();}《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
1.內(nèi)存中的用戶認(rèn)證在SpringSecurity安全框架中,InMemoryUserDetailsManager實現(xiàn)了UserDetailsService,以支持存儲在內(nèi)存中的用戶名/密碼的身份驗證。InMemoryUserDetailsManager通過實現(xiàn)UserDetailsMnager接口提供對UserDetails的管理。當(dāng)SpringSecurity配置為接受用戶名和密碼進(jìn)行身份驗證時,會使用基于UserDetails的身份驗證?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
1.內(nèi)存中的用戶認(rèn)證@BeanpublicUserDetailsServiceusers(){ UserDetailsuser=User.builder() .username("chenheng") .password("xxxx")
.roles("USER") .build(); UserDetailsadmin=User.builder() .username("admin") .password("yyyy")
.roles("DBA","ADMIN") .build(); returnnewInMemoryUserDetailsManager(user,admin);}《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
2.通用的用戶認(rèn)證我們在實際應(yīng)用中,可以查詢數(shù)據(jù)庫獲取用戶和權(quán)限,這時我們需要自定義實現(xiàn)org.springframework.security.core.userdetails.UserDetailsService接口的類,并重寫publicUserDetailsloadUserByUsername(Stringusername)方法查詢對應(yīng)的用戶和權(quán)限?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.1.4SpringSecurity的請求授權(quán)在SpringSecurity安全框架中,可以通過配置SecurityFilterChain完成用戶授權(quán)。示例代碼如下:@BeanpublicSecurityFilterChainfilterChain(HttpSecurityhttp)throwsException{ http .authorizeHttpRequests(authorize->authorize .requestMatchers("/xxx").permitAll() .requestMatchers("/user/**").hasRole("USER") //其他所有請求認(rèn)證授權(quán)后才能訪問
.anyRequest().authenticated() ); returnhttp.build();}《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.1.4SpringSecurity的請求授權(quán)在filterChain(HttpSecurityhttp)方法中,使用HttpSecurity的authorizeHttpRequests()方法的子節(jié)點給指定用戶授權(quán)訪問URL模式。我們可以通過requestMatchers()方法匹配URL路徑。匹配請求路徑后,可以針對當(dāng)前用戶對請求進(jìn)行安全處理。方法用途anyRequest()匹配所有請求路徑access(Stringattribute)SpringEL表達(dá)式結(jié)果為true時可以訪問anonymous()匿名可以訪問authenticated()用戶登錄后可訪問denyAll()用戶不能訪問fullyAuthenticated()用戶完全認(rèn)證可以訪問(非remember-me下自動登錄)hasAnyAuthority(String...)參數(shù)表示權(quán)限,用戶權(quán)限與其中任一權(quán)限相同就可以訪問hasAnyRole(String...)參數(shù)表示角色,用戶角色與其中任一角色相同就可以訪問hasAuthority(Stringauthority)參數(shù)表示權(quán)限,用戶權(quán)限與參數(shù)相同才可以訪問hasRole(Stringrole)參數(shù)表示角色,用戶角色與參數(shù)相同才可以訪問permitAll()任何用戶都可以訪問rememberMe()允許通過remember-me登錄的用戶訪問《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.1.5SpringSecurity的核心類SpringSecurity的核心類包括Authentication、DaoAuthenticationProvider、GrantedAuthority、PasswordEncoder、SecurityContextHolder、UserDetails和UserDetailsService?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
1.AuthenticationAuthentication用來封裝用戶認(rèn)證信息的接口,在用戶登錄認(rèn)證之前,SpringSecurity將相關(guān)信息封裝為一個Authentication具體實現(xiàn)類的對象,在登錄認(rèn)證成功后將生成一個信息更全面、包含用戶權(quán)限等信息的Authentication對象,然后將該對象保存在SecurityContextHolder所持有的SecurityContext中,方便后續(xù)程序進(jìn)行調(diào)用,如當(dāng)前用戶名、訪問權(quán)限等?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
2.SecurityContextHolderSecurityContextHolder顧名思義是用來持有SecurityContext的類。SecurityContext中包含當(dāng)前認(rèn)證用戶的詳細(xì)信息。SpringSecurity使用一個Authentication對象描述當(dāng)前用戶的相關(guān)信息。例如,最常見的是獲得當(dāng)前登錄用戶的用戶名和權(quán)限。privateStringgetUname(){
returnSecurityContextHolder.getContext().getAuthentication().getName();}privateStringgetAuthorities(){
Authenticationauthentication=SecurityContextHolder.getContext().getAuthentication();
List<String>roles=newArrayList<String>();
for(GrantedAuthorityga:authentication.getAuthorities()){
roles.add(ga.getAuthority());
}
returnroles.toString();}《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
3.UserDetailsUserDetails是SpringSecurity的一個核心接口。該接口定義了一些可以獲取用戶名、密碼、權(quán)限等與認(rèn)證相關(guān)的信息的方法。通常需要在應(yīng)用中獲取當(dāng)前用戶的其他信息,如Email、電話等。這時只包含認(rèn)證相關(guān)的UserDetails對象可能就不能滿足我們的需要了。我們可以實現(xiàn)自己的UserDetails,在該實現(xiàn)類中定義一些獲取用戶其他信息的方法,這樣我們就可以直接從當(dāng)前SecurityContext的Authentication的principal中獲取用戶的其他信息。Authentication.getPrincipal()的返回類型是Object,但通常返回的其實是一個UserDetails的實例,通過強(qiáng)制類型轉(zhuǎn)換可以將Object轉(zhuǎn)換為UserDetails類型。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
4.UserDetailsServiceUserDetails是通過UserDetailsService的loadUserByUsername(Stringusername)方法加載的。UserDetailsService也是一個接口,也需要實現(xiàn)自己的UserDetailsService來加載自定義的UserDetails信息。登錄認(rèn)證時,SpringSecurity將通過UserDetailsService的loadUserByUsername(Stringusername)方法獲取對應(yīng)的UserDetails進(jìn)行認(rèn)證,認(rèn)證通過后將該UserDetails賦給認(rèn)證通過的Authentication的principal,然后再將該Authentication保存在SecurityContext中。在應(yīng)用中,如果需要使用用戶信息,可以通過SecurityContextHolder獲取存放在SecurityContext中的Authentication的principal,即UserDetails實例。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
5.GrantedAuthorityAuthentication的getAuthorities()方法可以返回當(dāng)前Authentication對象擁有的權(quán)限(一個GrantedAuthority類型的數(shù)組),即當(dāng)前用戶擁有的權(quán)限。GrantedAuthority是一個接口,通常是通過UserDetailsService進(jìn)行加載,然后賦給UserDetails?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
6.DaoAuthenticationProvider在SpringSecurity安全框架中,默認(rèn)使用DaoAuthenticationProvider實現(xiàn)AuthenticationProvider接口進(jìn)行用戶認(rèn)證的處理。DaoAuthenticationProvider進(jìn)行認(rèn)證時,需要一個UserDetailsService來獲取用戶信息UserDetails。當(dāng)然我們可以實現(xiàn)自己的AuthenticationProvider,進(jìn)而改變認(rèn)證方式。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
7.PasswordEncoder在SpringSecurity安全框架中,是通過PasswordEncoder接口完成對密碼的加密。SpringSecurity對PasswordEncoder有多種實現(xiàn),包括MD5加密、SHA-256加密等,開發(fā)者只需直接使用即可。在SpringBoot應(yīng)用中,使用BCryptPasswordEncoder加密是較好的選擇。BCryptPasswordEncoder使用BCrypt的強(qiáng)散列哈希加密實現(xiàn),并可以由客戶端指定加密強(qiáng)度,強(qiáng)度越高安全性越高。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.1.6SpringSecurity的驗證機(jī)制SpringSecurity的驗證機(jī)制是由許多Filter實現(xiàn)的,F(xiàn)ilter將在SpringMVC前攔截請求,主要包括注銷Filter(LogoutFilter)、用戶名密碼驗證Filter(UsernamePasswordAuthenticationFilter)等內(nèi)容。Filter再交由其他組件完成細(xì)分的功能,最常用的UsernamePasswordAuthenticationFilter會持有一個AuthenticationManager引用,AuthenticationManager是一個驗證管理器,專門負(fù)責(zé)驗證。AuthenticationManager持有一個AuthenticationProvider集合,AuthenticationProvider是做驗證工作的組件,驗證成功或失敗之后調(diào)用對應(yīng)的Hanlder(處理)。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
目錄8.1SpringSecurity快速入門8.2SpringBoot的支持8.3實際開發(fā)中的SpringSecurity操作實例《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.2SpringBoot的支持在SpringBoot應(yīng)用中,我們只需引入spring-boot-starter-security依賴即可使用SpringSecurity安全框架,這是因為SpringBoot對SpringSecurity提供了自動配置功能。從org.springframework.boot.autoconfigure.security.SecurityProperties類中,我們可以看到使用以“spring.security”為前綴的屬性配置了SpringSecurity的相關(guān)默認(rèn)配置?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
目錄8.1SpringSecurity快速入門8.2SpringBoot的支持8.3實際開發(fā)中的SpringSecurity操作實例《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例【例7-1】在SpringBoot應(yīng)用中,使用基于SpringDataJPA的SpringSecurity安全框架。1.創(chuàng)建SpringBootWeb應(yīng)用ch8創(chuàng)建基于Lombok、SpringDataJPA、Thymeleaf及SpringSecurity的Web應(yīng)用ch8,如圖8.1所示?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例2.修改pom.xml文件,添加MySQL依賴在pom.xml文件中添加MySQL連接器依賴,配置內(nèi)容與【例6-1】中的相同,不再贅述。3.設(shè)置Web應(yīng)用ch8的上下文路徑及數(shù)據(jù)源配置信息在應(yīng)用ch8的perties文件中配置內(nèi)容與【例6-1】中的相同,不再贅述。4.整理腳本樣式靜態(tài)文件JS腳本、CSS樣式、圖片等靜態(tài)文件默認(rèn)放置在src/main/resources/static目錄下,ch8應(yīng)用引入的BootStrap和jQuery與【例5-5】中的一樣,不再贅述?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例5.創(chuàng)建用戶和權(quán)限持久化實體類在應(yīng)用ch8的src/main/java目錄下,創(chuàng)建名為com.ch.ch8.entity的包,并在該包中創(chuàng)建持久化實體類MyUser和Authority。MyUser類用來保存用戶數(shù)據(jù),用戶名唯一。Authority用來保存權(quán)限信息。用戶和權(quán)限是多對多的關(guān)系?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例6.創(chuàng)建數(shù)據(jù)訪問層接口在應(yīng)用ch8的src/main/java目錄下,創(chuàng)建名為com.ch.ch8.repository的包,并在該包中創(chuàng)建名為MyUserRepository的接口,該接口繼承了JpaRepository,核心代碼如下:publicinterfaceMyUserRepositoryextendsJpaRepository<MyUser,Integer>{ //根據(jù)用戶名查詢用戶,方法名命名符合SpringDataJPA規(guī)范
MyUserfindByUsername(Stringusername);}在com.ch.ch8.repository包中,創(chuàng)建名為AuthorityRepository的接口,該接口繼承了JpaRepository,具體代碼如下:publicinterfaceAuthorityRepositoryextendsJpaRepository<Authority,Integer>{}《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例7.創(chuàng)建業(yè)務(wù)層在應(yīng)用ch8的src/main/java目錄下,創(chuàng)建名為com.ch.ch8.service的包,并在該包中創(chuàng)建UserService接口和UserServiceImpl實現(xiàn)類?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例8.創(chuàng)建控制器類在應(yīng)用ch8的src/main/java目錄下,創(chuàng)建名為com.ch.ch8.controller的包,并在該包中創(chuàng)建控制器類TestSecurityController?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例9.創(chuàng)建應(yīng)用的安全控制相關(guān)實現(xiàn)在應(yīng)用ch8的src/main/java目錄下,創(chuàng)建名為com.ch.ch8.security的包,并在該包中創(chuàng)建MyUserSecurityService、MyAuthenticationSuccessHandler和SpringSecurityConfig類。MyUserSecurityService實現(xiàn)了UserDetailsService接口,并通過重寫loadUserByUsername(Stringusername)方法查詢對應(yīng)的用戶,并將用戶名、密碼、權(quán)限等與認(rèn)證相關(guān)的信息封裝在UserDetails對象中。《SpringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例MyAuthenticationSuccessHandler繼承了SimpleUrlAuthenticationSuccessHandler類,并重寫了handle(HttpServletRequestrequest,HttpServletResponseresponse,Authenticationauthentication)方法,根據(jù)當(dāng)前認(rèn)證用戶的角色指定對應(yīng)的URL。SpringSecurityConfig類是認(rèn)證和授權(quán)處理的配置類,需要使用@Configuration和@EnableWebSecurity注解。在該類中配置了加密規(guī)則、認(rèn)證實現(xiàn)方式、認(rèn)證管理器以及授權(quán)操作?!禨pringBoot從入門到實戰(zhàn)(第2版·微課視頻版)》陳恒
主編,清華大學(xué)出版社,2024
8.3實際開發(fā)中的SpringSecurity操作實例10.創(chuàng)建用于測試的視圖頁
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 獨立董事2025年度履職評價與激勵措施合同3篇
- 二零二五年度禾青幼兒園教玩具采購與幼兒園設(shè)施維護(hù)合同3篇
- 二零二五搬家公司合同模板:搬家保險責(zé)任與賠償條款2篇
- 二零二五版物流行業(yè)預(yù)付款擔(dān)保合同2篇
- 二零二五版搬家服務(wù)與家政服務(wù)融合合同樣本2篇
- 二零二五年度蔬菜電子商務(wù)合同:線上銷售平臺與賣家之間的規(guī)則2篇
- 二零二五版汽車零部件購銷合同標(biāo)準(zhǔn)及售后服務(wù)模板3篇
- 二零二五年度國際教育機(jī)構(gòu)合作辦學(xué)合同3篇
- 二零二五年度高壓變壓器安裝及安全防護(hù)技術(shù)合同3篇
- 二零二五版社保繳納與工傷保險待遇保障合同3篇
- 《項目施工組織設(shè)計開題報告(含提綱)3000字》
- ICU常見藥物課件
- CNAS實驗室評審不符合項整改報告
- 農(nóng)民工考勤表(模板)
- 承臺混凝土施工技術(shù)交底
- 臥床患者更換床單-軸線翻身
- 計量基礎(chǔ)知識培訓(xùn)教材201309
- 中考英語 短文填詞、選詞填空練習(xí)
- 阿特拉斯基本擰緊技術(shù)ppt課件
- 初一至初三數(shù)學(xué)全部知識點
- 新課程理念下的班主任工作藝術(shù)
評論
0/150
提交評論