一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|

服務器之家 - 編程語言 - JAVA教程 - 淺談spring security入門

淺談spring security入門

2020-07-09 11:29知識追尋者 JAVA教程

這篇文章主要介紹了淺談spring security入門,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一 介紹

本節給知識追尋者給大家帶來的是springSecurity入門篇,主要是簡述下springSecrurity的啟動原理和簡單的入門搭建;

二 核心模塊介紹

  • spring-security-core ; 包含核心身份驗證和access-contol類和接口,遠程支持和基本配置AP;
  • spring-security-web: web , url登陸驗證和訪問控制;
  • spring-security-config: 支持xml 或者java注解配置;

當然其模塊遠不止這些,比如CAS,ALC,Aspects,OpenI等等,對于入門我們了解核心即可;

三 入門搭建

3.1 依賴

springboot 2.3.0

?
1
2
3
4
<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-security</artifactId>
   </dependency>

3.2 控制層

控制層定義一個接口,用于瀏覽器請求,請求成功后會返回 hello zszxz ;

?
1
2
3
4
5
@GetMapping("hello")
  public String hello() {
 
    return "hello zszxz";
  }

3.3 訪問登陸頁

啟動項目

訪問 localhost:8080/hello 會自動跳轉至localhost:8080/login

淺談spring security入門

可以看到 接口就被保護起來了,訪問接口需要進行賬號密碼登陸;那么賬號密碼在哪里?看tiao控制臺打印的日志

如下所示,一串uuid就是登陸密碼;賬號是 user;賬號,密碼輸入后就會跳轉至 localhost:8080/hello ;

.UserDetailsServiceAutoConfiguration :

Using generated security password: 8f5b8238-9b35-482f-b2a5-bf440af5271b

3.4 登陸原理解析

由日志打印可以看出 是在 UserDetailsServiceAutoConfiguration 類中發現的密碼;我們點擊該類發現有個

inMemoryUserDetailsManager 方法 里面有 properties.getUser(); 即獲取用戶,說明用戶信息來自 SecurityProperties ;

?
1
2
3
4
5
6
@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”

?
1
2
3
4
5
6
7
8
9
10
11
12
@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配置賬號密碼如下

?
1
2
3
4
5
spring:
 security:
  user:
   password: zszxz
   name: zszxz

重啟服務,訪問http://localhost:8080/login 此時 的填入的表單賬號密碼就是zszxz; 而且發現 控制臺不再打印出uuid ;

3.5 springSecurity基本原理

仔細檢測日志信息, 可以發現springSecurity模塊的日志打印信息如下,其實現原理就是通過一串的Servlet過濾器進行基本實現,最后一個是FilterSecurityInterceptor 攔截器;

?
1
2
3
[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 功能都不同,以后可能提到,有興趣的讀者也可以參照官網學習;

淺談spring security入門

比較重要的Filter

  • UsernamePasswordAuthenticationFilter
  • DigestAuthenticationFilter
  • BasicAuthenticationFilter
  • ExceptionTranslationFilter
  • FilterSecurityInterceptor

四 加密方式

官網有列出 基于 withDefaultPasswordEncoder 方式 創建 用戶,這樣并不是很推薦,原因是其賬號密碼會暴露在內存和編譯的源碼中,并不是很安全,如果要用于生產環境還需要對密碼進行一次hash或者加密;

?
1
2
3
4
5
6
7
8
9
10
11
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();

官方提供了好多種其它方式進行加密:

  • DelegatingPasswordEncoder
  • BCryptPasswordEncoder
  • Argon2PasswordEncoder
  • Pbkdf2PasswordEncoder
  • SCryptPasswordEncoder

它們的使用方式都差不多,示例如下,在使用時替換對應的加密對象即可;

?
1
2
3
SCryptPasswordEncoder encoder = new SCryptPasswordEncoder();
String result = encoder.encode("myPassword");
assertTrue(encoder.matches("myPassword", result));

五 參考文檔

https://docs.spring.io/spring-security/site/docs/5.3.3.BUILD-SNAPSHOT/reference/html5/

到此這篇關于淺談spring security入門 的文章就介紹到這了,更多相關spring security入門 內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/youku1327/article/details/106560125

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本一本草久p | 欧美黑人ⅹxxx片 | 精品国产区一区二区三区在线观看 | 欧洲网色偷偷亚洲男人的天堂 | 亚洲精品国产成人 | a优女网| 热久久免费 | 亚洲一卡2卡4卡5卡6卡残暴在线 | 91精品国产高清久久久久久 | 91在线永久 | 国产伦精品一区二区三区免费迷 | 欧美精品一二三区 | 被老外玩爽的中国美女视频 | 毛片免费全部免费观看 | yellow最新视频2019| 超兴奋朋友的中文字幕下 | 国色天香社区视频在线观看免费完整版 | 婷婷久久综合九色综合九七 | 羞羞答答影院在线 | 国产亚洲精aa在线观看不卡 | 国产欧美精品一区二区三区四区 | 千金奴隶在线 | 成年女人毛片免费观看97 | 户外露出野战hd | a天堂视频| 亚洲一卡2卡三卡4卡5卡组 | 国产第9页 | 亭亭色| 双子母性本能在线观看 | 久久这里只有精品国产精品99 | 高h文恩好大好爽 | 欧美一级在线播放 | 91麻豆精品国产片在线观看 | 外国黄色软件 | 99在线精品日韩一区免费国产 | 卫生间被教官做好爽HH视频 | 成年视频在线观看 | 亚欧视频在线观看 | 四虎成人免费视频 | 亚洲国产精品网 | 深夜网站在线观看 |