淺聊一下Spring?Security的使用方法
本文,我們來說說 Spring Security
。
spring security 是什么?
Spring Security
是一個基于 Spring
框架的安全框架,提供了一套安全性認證和授權的解決方案,用于保護 Web
應用程序和服務。
Spring Security 提供了多種身份驗證和授權方式,例如基于表單的身份驗證和授權方式、基于 HTTP
基本身份驗證、基于 OAuth2
的身份驗證等。
Spring Security 還提供了許多常見的安全特性,比如防止跨站點請求偽造 CSRF
攻擊、防止點擊劫持等。
CSRF -> Cross-Site Request Forgery
Spring Security 核心概念
它有三個核心概念,如下:
概念 | 說明 |
---|---|
Principle | 代表用戶的對象 Principle(User) ,不僅指人類,還包括一切可以用于驗證的設備。 |
Authority | 代表用戶的角色 Authority(Role) ,每個用戶都應該有一種角色,例如管理員或者是會員。 |
Permission | 代表授權,復雜的應用環(huán)境需要對角色的權限進行表述。 |
Authority
和 Permission
是兩個完全獨立的概念,兩者沒有必然的聯(lián)系。它們直接需要通過配置進行關聯(lián),可以是自己定義的各種關系。
案例
首先,我們添加依賴:
<!-- Spring Security --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency>
我們啟動項目,可以在控制臺上看到動態(tài)生成的訪問密碼:
默認的用戶名是 user
這個時候,我們在瀏覽器上訪問用戶列表接口 http://localhost:8080/api/user/
,會自動跳轉到登陸頁面。
輸入默認用戶名 user
和上圖中動態(tài)生成的密碼 3019398a-a10f-43e9-9e21-199f6892f689
,登陸成功后,自動跳轉到接口 http://localhost:8080/api/user/
。
當然,我們也可以自定用戶名和密碼,不然每次啟動項目后,密碼都需要重新生成一遍,著實尷尬。
自定義用戶名和密碼
方式一: 在 application.properties
文件內配置:
spring.security.user.name=jimmy spring.security.user.password=123456
重啟項目,輸入用戶名 jimmy
,密碼 123456
即可授權登陸。
如果不生效,請清空瀏覽器上的緩存
方式二: Java 上配置用戶名和密碼:
在包 config
下,新建文件 SecurityConfig.java
,如下:
package com.launch.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; import org.springframework.security.crypto.password.PasswordEncoder; @Configuration public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { BCryptPasswordEncoder encoder = new BCryptPasswordEncoder(); // 用戶存在內存中 auth.inMemoryAuthentication() .withUser("jimmy") .password(encoder.encode("111111")) .roles("admin") .and() .withUser("kimmy") .password(encoder.encode("222222")) .roles("user"); } @Bean PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); } }
注意,密碼需要加密,如 encoder.encode("222222")
。
重啟項目,清空瀏覽器緩存,輸入用戶名/密碼 - kimmy / 222222
或者 jimmy / 111111
即可登陸。
PostMan 上統(tǒng)一設定憑證
在現(xiàn)實的開發(fā)中,我們使用 Postman
工具調試的多點,那么我們怎么操作呢?
第一步,設定環(huán)境變量,這里設置 username
和 password
就行了:
這里設置的變量名為 username 和 password
然后,我們在接口上配置認證信息,比如這里的獲取用戶列表的接口:
選擇 Type 為 Basic Auth,填寫上面第一步??設定的變量
{{username}}
和{{password}}
到此這篇關于淺聊一下Spring Security的使用方法的文章就介紹到這了,更多相關Spring Security用法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringSecurity構建基于JWT的登錄認證實現(xiàn)
這篇文章主要介紹了SpringSecurity構建基于JWT的登錄認證實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02Java hashCode原理以及與equals()區(qū)別聯(lián)系詳解
在 Java 應用程序執(zhí)行期間,在同一對象上多次調用 hashCode 方法時,必須一致地返回相同的整數(shù),前提是對象上 equals 比較中所用的信息沒有被修改。從某一應用程序的一次執(zhí)行到同一應用程序的另一次執(zhí)行,該整數(shù)無需保持一致2022-11-11解決SpringBoot返回結果如果為null或空值不顯示處理問題
這篇文章主要介紹了解決SpringBoot返回結果如果為null或空值不顯示處理問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07java利用socket通信實現(xiàn)Modbus-RTU通信協(xié)議的示例代碼
這篇文章主要介紹了java利用socket通信實現(xiàn)Modbus-RTU通信協(xié)議的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04SpringBoot實現(xiàn)HTTP調用的7 種方式
本文主要介紹了SpringBoot實現(xiàn)HTTP調用的7 種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-04-04