一 介紹
給知識追尋者給大家帶來的是springSecurity入門篇,主要是簡述下springSecrurity的啟動原理和簡單的入門搭建;
二 核心模塊介紹
當然其模塊遠不止這些,比如CAS,ALC,Aspects,OpenI等等,對于入門我們了解核心即可;
三 入門搭建
3.1 依賴
springboot 2.3.0
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency>
3.2 控制層
控制層定義一個接口,用于瀏覽器請求,請求成功后會返回 hello zszxz
;
@GetMapping("hello") public String hello() { return "hello zszxz"; }
3.3 訪問登陸頁
啟動項目
訪問 localhost:8080/hello 會自動跳轉至localhost:8080/login
可以看到 接口就被保護起來了,訪問接口需要進行賬號密碼登陸;那么賬號密碼在哪里?看tiao控制臺打印的日志
如下所示,一串uuid就是登陸密碼;賬號是 user;賬號,密碼輸入后就會跳轉至 localhost:8080/hello ;
.UserDetailsServiceAutoConfiguration :
Using generated security password: 8f5b8238-9b35-482f-b2a5-bf440af5271b
3.4 登陸原理解析
由日志打印可以看出 是在 UserDetailsServiceAutoConfiguration
類中發現的密碼;我們點擊該類發現有個
inMemoryUserDetailsManager
方法 里面有 properties.getUser(); 即獲取用戶,說明用戶信息來自 SecurityProperties
;
@Lazy public InMemoryUserDetailsManager inMemoryUserDetailsManager(SecurityProperties properties, ObjectProvider<PasswordEncoder> passwordEncoder) { User user = properties.getUser(); List<String> roles = user.getRoles(); return new InMemoryUserDetailsManager(new UserDetails[]{org.springframework.security.core.userdetails.User.withUsername(user.getName()).password(this.getOrDeducePassword(user, (PasswordEncoder)passwordEncoder.getIfAvailable())).roles(StringUtils.toStringArray(roles)).build()}); }
點擊 SecurityProperties
類其有個內部靜態類User, 如下所示,賬號就是user, 密碼就是UUID; roles是個ArrayList;配置文件的前綴 “spring.security”
@ConfigurationProperties( prefix = "spring.security")public class SecurityProperties {// 此處省略.........public static class User { private String name = "user"; private String password = UUID.randomUUID().toString(); private List<String> roles = new ArrayList(); private boolean passwordGenerated = true;// 此處省略.........
現在我們通過配置文件的方式改變賬號密碼,在application.yml配置賬號密碼如下
spring: security: user: password: zszxz name: zszxz
重啟服務,訪問http://localhost:8080/login 此時 的填入的表單賬號密碼就是zszxz
; 而且發現 控制臺不再打印出uuid ;
3.5 springSecurity基本原理
仔細檢測日志信息, 可以發現springSecurity模塊的日志打印信息如下,其實現原理就是通過一串的Servlet過濾器進行基本實現,最后一個是FilterSecurityInterceptor
攔截器;
[org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter@248deced, org.springframework.security.web.context.SecurityContextPersistenceFilter@677b8e13, org.springframework.security.web.header.HeaderWriterFilter@30331109, org.springframework.security.web.csrf.CsrfFilter@1bbae752, org.springframework.security.web.authentication.logout.LogoutFilter@64030b91, org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter@78faea5f,............... .intercept.FilterSecurityInterceptor@2b4c3c29
來自官網的圖片如下;FilterChain 中包含了 Filter 和 Servlet , 其能夠很快速的處理所有的URL請求; 當然每個具體的Filter 功能都不同,以后可能提到,有興趣的讀者也可以參照官網學習;
比較重要的Filter
四 加密方式
官網有列出 基于 withDefaultPasswordEncoder 方式 創建 用戶,這樣并不是很推薦,原因是其賬號密碼會暴露在內存和編譯的源碼中,并不是很安全,如果要用于生產環境還需要對密碼進行一次hash或者加密;
UserBuilder users = User.withDefaultPasswordEncoder();User user = users .username("user") .password("password") .roles("USER") .build();User admin = users .username("admin") .password("password") .roles("USER","ADMIN") .build();
官方提供了好多種其它方式進行加密:
它們的使用方式都差不多,示例如下,在使用時替換對應的加密對象即可;
SCryptPasswordEncoder encoder = new SCryptPasswordEncoder();String result = encoder.encode("myPassword");assertTrue(encoder.matches("myPassword", result));
看完了這篇文章,相信你對springsecurity是什么有什么用有了一定的了解,想了解更多相關知識,歡迎關注本站行業資訊頻道,感謝各位的閱讀!
本文由 貴州做網站公司 整理發布,部分圖文來源于互聯網,如有侵權,請聯系我們刪除,謝謝!
c語言中正確的字符常量是用一對單引號將一個字符括起表示合法的字符常量。例如‘a’。數值包括整型、浮點型。整型可用十進制,八進制,十六進制。八進制前面要加0,后面...
2022年天津專場考試原定于3月19日舉行,受疫情影響確定延期,但目前延期后的考試時間推遲。 符合報名條件的考生,須在規定時間登錄招考資訊網(www.zha...
:喜歡聽,樂意看。指很受歡迎?!巴卣官Y料”喜聞樂見:[ xǐ wén lè jiàn ]詳細解釋1. 【解釋】:喜歡聽,樂意看。指很受歡迎。2. 【示例】:這是...
(資料圖)最近這段時間總有小伙伴問小編CPU溫度過高怎么設置自動關機是什么,小編為此在網上搜尋了一些有關于CPU溫度過高怎么設置自動關機的知識送給大家,希望能解答各位小伙伴的疑惑。CPU溫度過高時,設置自動關機臨界溫度的方法步驟如下:1、進入BIOS后,在左邊一列找PChealth,重點是health這個詞;2、在health中找到關機溫度,和報警溫度;3、對這兩個溫度進行設置,就能設置報警溫度和...
全球通銀卡客戶是什么意思?全球通銀卡客戶是指客戶在中國移動的一種等級。全球通銀卡指的是全球通客戶的評級是銀卡等級,是指客戶在中國移動的評定等級。根據不同的評級,移動客戶可以享受的權益也不-樣。其中,全球通銀卡可以享受全球最高的服務。全球通銀卡的加入條件全球通銀卡的添加標準是戶在網上年度的消費積分需要超過2900分,并且戶需要為中國移動通訊“全球通”的品牌客戶。全球通銀卡的積...
在實際的經濟生活中,中央銀行的三大法寶一般認為是存款準備金政策、公開市場業務政策以及再貼現政策。利用以上這三三大法寶,中央銀行需要對市場金融秩序進行宏觀調控,實現對市場內信用總量進行統一的收縮或者擴張操作。央銀三大法寶的詳情介紹1、存款準備金政策:中央銀行通過對存款準備金率進行調控,從而影響金融機構的實際影響能力,間接的來調控市場內貨幣的供應總量;2、公開市場業務政策:公開市場業務政策即意味著中央...