欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JAVA中Spring Security示例及常見問題

 更新時間:2025年07月29日 10:21:23   作者:真上帝的左手  
文章概述Spring Security OAuth2與JWT模塊的版本兼容性及遷移建議,強調2.5.x支持JDK8但已棄用,推薦新項目使用SpringAuthorizationServer(Spring Boot3.x+),并指出依賴沖突、配置示例及密鑰安全注意事項,感興趣的朋友一起看看吧

前言

Spring Security

  • spring-security-oauth2
  • spring-security-jwt

一、spring-security-oauth2

  1. 各版本的名稱及發(fā)布日期:
版本適用 Spring Boot適用 Spring Security狀態(tài)備注‌
‌2.5.x2.5.x - 2.7.x5.5.x - 5.7.x‌維護中推薦穩(wěn)定版
‌2.4.x2.4.x - 2.6.x5.4.x - 5.6.x已棄用建議升級
‌2.3.x2.3.x - 2.5.x5.3.x - 5.5.x已棄用不推薦
‌2.2.x2.2.x - 2.4.x5.2.x - 5.4.x已棄用僅舊項目
‌2.1.x2.1.x - 2.3.x5.1.x - 5.3.x已棄用不推薦
  1. Spring Boot 2.7.x + JDK 8‌的環(huán)境推薦版本‌
<dependency>
    <groupId>org.springframework.security.oauth</groupId>
    <artifactId>spring-security-oauth2</artifactId>
    <version>2.5.2.RELEASE</version> <!-- 最新穩(wěn)定版 -->
</dependency>
  1. Spring Security‌ 版本匹配
<dependency>
    <groupId>org.springframework.security</groupId>
    <artifactId>spring-security-core</artifactId>
    <version>5.7.6</version> <!-- 推薦版本 -->
</dependency>
  1. 注意事項‌
  • Spring Security OAuth2 已棄用‌
  • 官方推薦遷移到 ‌Spring Authorization Server‌(Spring Security 5.7+ 內置)
  • 新項目建議直接使用 spring-security-oauth2-authorization-server(Spring Boot 3.x+)
  • ‌JDK 8 兼容性‌

    • Spring Security OAuth2 2.5.x 仍支持 JDK 8
    • 如需升級到 Spring Boot 3.x,需切換至 JDK 17+
  • ‌常見問題‌

    • 如果遇到 NoSuchMethodError,檢查依賴沖突(如舊版 spring-security-jwt)
    • 推薦使用 spring-security-oauth2-autoconfigure 簡化配置
  1. 遷移建議‌

如果計劃升級,可參考以下路徑:

  • 短期方案‌:繼續(xù)使用 OAuth2 2.5.x(維護模式)
  • 長期方案‌:遷移到 ‌Spring Authorization Server‌(需要 Spring Boot 3.x+)
  1. Spring Authorization Server‌

二、spring-security-jwt

  • 版本選擇‌
  • ‌spring-security-jwt‌ 最終穩(wěn)定版:
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-jwt</artifactId>
        <version>1.1.1.RELEASE</version> <!-- 官方最后維護版本 -->
    </dependency>
  • 兼容性說明‌:
    • 需搭配 spring-security-oauth2 2.5.x 使用(如 2.5.2.RELEASE)。
    • 不支持 Spring Boot 3.x 或 JDK 17+。

‌2. 基礎配置示例‌

  • ‌JWT 密鑰配置‌
    JwtConfig.java
@Configuration
public class JwtConfig {
    @Value("${jwt.secret}")
    private String secret;
    @Bean
    public JwtAccessTokenConverter jwtAccessTokenConverter() {
        JwtAccessTokenConverter converter = new JwtAccessTokenConverter();
        converter.setSigningKey(secret); // 設置簽名密鑰
        return converter;
    }
    @Bean
    public TokenStore tokenStore() {
        return new JwtTokenStore(jwtAccessTokenConverter());
    }
}
  • 需在 application.properties 中配置 jwt.secret=your-256-bit-secret。
  • ‌OAuth2 資源服務器配置‌
  • ResourceServerConfig.java
@Configuration
@EnableResourceServer
public class ResourceServerConfig extends ResourceServerConfigurerAdapter {
    @Override
    public void configure(HttpSecurity http) throws Exception {
        http
            .authorizeRequests()
            .antMatchers("/api/public/**").permitAll()
            .anyRequest().authenticated();
    }
}

‌3. 生成和解析 JWT 令牌‌

  • ‌生成令牌(授權服務器端)‌
    JwtTokenEnhancer.java
 class JwtTokenEnhancer implements TokenEnhancer {
    @Override
    public OAuth2AccessToken enhance(
        OAuth2AccessToken accessToken,
        OAuth2Authentication authentication) {
        Map<String, Object> additionalInfo = new HashMap<>();
        additionalInfo.put("organization", "example-org");
        ((DefaultOAuth2AccessToken) accessToken)
            .setAdditionalInformation(additionalInfo);
        return accessToken;
    }
}
  • ‌解析令牌(資源服務器端)‌
    JwtUtils.java
 class JwtUtils {
    public static Claims extractClaims(String token, String secret) {
        return Jwts.parser()
            .setSigningKey(secret.getBytes())
            .parseClaimsJws(token)
            .getBody();
    }
}

‌4. 注意事項‌

  • 密鑰安全‌:
    • 替換 JwtAccessTokenConverter 的簽名邏輯)。
  • 依賴沖突‌:
    • 避免引入 jjwt 舊版本(如 0.9.x),可能引發(fā) NoSuchMethodError。
  • 遷移建議‌:
    • 新項目推薦使用 spring-security-oauth2-authorization-server + jjwt 0.12.x。
  1. jjwt

到此這篇關于JAVA中Spring Security示例及常見問題的文章就介紹到這了,更多相關Spring Security示例內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java中如何正確重寫equals方法

    Java中如何正確重寫equals方法

    Object類中equals方法比較的是兩個對象的引用地址,只有對象的引用地址指向同一個地址時,才認為這兩個地址是相等的,否則這兩個對象就不相等
    2021-10-10
  • Springboot項目如何異步提高接口的響應速度

    Springboot項目如何異步提高接口的響應速度

    這篇文章主要介紹了Springboot項目如何異步提高接口的響應速度方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-06-06
  • 關于Https協(xié)議和HttpClient的實現(xiàn)詳解

    關于Https協(xié)議和HttpClient的實現(xiàn)詳解

    這篇文章主要給大家介紹了關于Https協(xié)議和HttpClient實現(xiàn)的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-05-05
  • Java中如何避免sql注入實例詳解

    Java中如何避免sql注入實例詳解

    SQL注入是最常見的攻擊方式之一,它不是利用操作系統(tǒng)或其它系統(tǒng)的漏洞來實現(xiàn)攻擊的,而是程序員因為沒有做好判斷,被不法用戶鉆了SQL的空子,下面這篇文章主要給大家介紹了關于Java中如何避免sql注入的相關資料,需要的朋友可以參考下
    2022-01-01
  • Springboot使用jsp具體案例解析

    Springboot使用jsp具體案例解析

    這篇文章主要介紹了Springboot使用jsp具體案例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Javaweb-HttpServletResponse的sendRedirectch重定向方式

    Javaweb-HttpServletResponse的sendRedirectch重定向方式

    這篇文章主要介紹了Javaweb-HttpServletResponse的sendRedirectch重定向方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • httpclient的CPool定義方法詳解

    httpclient的CPool定義方法詳解

    這篇文章主要為大家介紹了httpclient的CPool定義方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • Java使用excel工具類導出對象功能示例

    Java使用excel工具類導出對象功能示例

    這篇文章主要介紹了Java使用excel工具類導出對象功能,結合實例形式分析了java創(chuàng)建及導出Excel數(shù)據(jù)的具體步驟與相關操作技巧,需要的朋友可以參考下
    2017-10-10
  • Java微信小程序oss圖片上傳的實現(xiàn)方法

    Java微信小程序oss圖片上傳的實現(xiàn)方法

    這篇文章主要介紹了Java微信小程序oss圖片上傳的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • Spring外部化配置的幾種技巧分享

    Spring外部化配置的幾種技巧分享

    在油管上看了龍之春的一個Spring tips 視頻,講述Spring外部化配置的幾種技巧,收獲頗多,想拿出來給大家分享下。對spring感興趣的朋友可以了解下本文
    2021-06-06

最新評論