0

0

SpringSecurity6安全实战:OAuth2.0与JWT集成最佳实践

夢幻星辰

夢幻星辰

发布时间:2025-09-03 21:07:01

|

647人浏览过

|

来源于php中文网

原创

spring security 6集成oauth 2.0和jwt需引入授权服务器与资源服务器依赖,配置客户端详情、jwt解码器及授权规则,通过jwtclaimssetcustomizer定制声明,使用bcrypt等安全密码编码,结合clientregistrationrepository实现第三方登录,利用spel或accessdecisionvoter实现细粒度权限控制,支持刷新令牌机制,并通过黑名单、短有效期或服务端存储应对jwt吊销问题。

springsecurity6安全实战:oauth2.0与jwt集成最佳实践

Spring Security 6 中集成 OAuth 2.0 和 JWT,核心在于构建一个安全的、可扩展的授权体系,让你的应用能够代表用户安全地访问受保护的资源。 这不仅提升了安全性,还简化了跨应用的用户认证和授权流程。

OAuth 2.0 + JWT 集成方案

  1. 依赖引入: 首先,确保你的

    pom.xml
    文件中包含了 Spring Security OAuth2 相关依赖。 核心依赖包括
    spring-boot-starter-oauth2-authorization-server
    spring-boot-starter-oauth2-resource-server

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-oauth2-authorization-server</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-oauth2-resource-server</artifactId>
    </dependency>
  2. 配置授权服务器: 创建一个配置类来定义授权服务器的行为。 你需要配置客户端详情(client details),包括客户端 ID、密钥、授权类型(authorization grant types)、重定向 URI 和 scope。

    @Configuration
    @EnableWebSecurity
    public class AuthorizationServerConfig {
    
        @Bean
        public RegisteredClientRepository registeredClientRepository() {
            RegisteredClient registeredClient = RegisteredClient.withId(UUID.randomUUID().toString())
                    .clientId("your-client-id")
                    .clientSecret("{noop}your-client-secret") // 生产环境不要用 noop
                    .clientAuthenticationMethod(ClientAuthenticationMethod.CLIENT_SECRET_BASIC)
                    .authorizationGrantType(AuthorizationGrantType.AUTHORIZATION_CODE)
                    .authorizationGrantType(AuthorizationGrantType.REFRESH_TOKEN)
                    .redirectUri("http://127.0.0.1:8080/login/oauth2/code/your-client-id")
                    .scope(OidcScopes.OPENID)
                    .scope("read")
                    .build();
    
            return new InMemoryRegisteredClientRepository(registeredClient);
        }
    
        @Bean
        public ProviderSettings providerSettings() {
            return ProviderSettings.builder().issuer("http://auth-server:9000").build();
        }
    
        // ... 其他配置,例如 JWKSource
    }
  3. 配置资源服务器: 资源服务器需要知道如何验证 JWT。 你需要配置 JWT 解码器(JWT Decoder)和授权规则。

    @Configuration
    @EnableWebSecurity
    public class ResourceServerConfig {
    
        @Bean
        public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
            http
                .authorizeHttpRequests((authorize) -> authorize
                    .requestMatchers("/public/**").permitAll()
                    .anyRequest().authenticated()
                )
                .oauth2ResourceServer((oauth2) -> oauth2.jwt(Customizer.withDefaults()));
            return http.build();
        }
    }
  4. JWT 定制: 可以通过实现

    JwtClaimsSetCustomizer
    接口来定制 JWT 的内容。 例如,添加用户角色或自定义声明。

    @Bean
    public JwtClaimsSetCustomizer<OAuth2TokenClaimsContext> jwtClaimsSetCustomizer() {
        return context -> {
            // 添加自定义声明
            context.getClaims().claim("custom-claim", "some-value");
        };
    }
  5. 安全性考量: 永远不要在生产环境中使用

    {noop}
    作为密码编码器。 使用像 BCrypt 或 Argon2 这样的强密码哈希算法。 此外,定期轮换你的 JWT 签名密钥。

Spring Security 6 OAuth 2.0 授权码模式如何集成第三方登录?

集成第三方登录的关键在于配置

ClientRegistrationRepository
和处理回调。 你需要在
application.yml
application.properties
文件中配置第三方 OAuth 2.0 提供商的客户端 ID、密钥、授权和令牌端点。

spring:
  security:
    oauth2:
      client:
        registration:
          github:
            client-id: your-github-client-id
            client-secret: your-github-client-secret
            redirect-uri: "{baseUrl}/login/oauth2/code/{registrationId}"
            scope: read:user
        provider:
          github:
            authorization-uri: https://github.com/login/oauth/authorize
            token-uri: https://github.com/login/oauth/access_token
            user-info-uri: https://api.github.com/user
            user-name-attribute: id

然后,你可以使用

@EnableOAuth2Sso
注解来启用单点登录(SSO)。 Spring Security 会自动处理授权码流程和用户信息的获取。

AI神器大全
AI神器大全

AI工具集合导航站

下载

Spring Security 6 OAuth 2.0 如何实现资源服务器的细粒度权限控制?

细粒度权限控制通常涉及到使用 Spring Security 的表达式语言(SpEL)或自定义的

AccessDecisionVoter
。 你可以在
@PreAuthorize
@PostAuthorize
注解中使用 SpEL 表达式来定义访问规则。

@GetMapping("/admin/users/{userId}")
@PreAuthorize("hasRole('ADMIN') and #userId == principal.id")
public User getUser(@PathVariable Long userId) {
    // ...
}

或者,你可以创建一个自定义的

AccessDecisionVoter
来实现更复杂的权限逻辑。 这允许你根据请求的上下文、用户属性和资源属性来动态地决定是否授权访问。

JWT 的刷新令牌(Refresh Token)机制在 Spring Security 6 中如何实现?

刷新令牌允许客户端在访问令牌过期后,无需用户重新授权即可获取新的访问令牌。 你需要在授权服务器中配置刷新令牌的支持,并确保客户端在获取访问令牌时也请求刷新令牌。

@Bean
public AuthorizationServerSettings authorizationServerSettings() {
    return AuthorizationServerSettings.builder()
            .authorizationEndpoint("/oauth2/authorize")
            .tokenEndpoint("/oauth2/token")
            .tokenRevocationEndpoint("/oauth2/revoke")
            .jwkSetEndpoint("/oauth2/jwks")
            .build();
}

当访问令牌过期时,客户端可以使用刷新令牌向授权服务器请求新的访问令牌。 授权服务器会验证刷新令牌的有效性,并颁发新的访问令牌和刷新令牌。

如何处理 JWT 的吊销(Revocation)问题?

JWT 本身是自包含的,一旦颁发就无法直接撤销。 但是,你可以通过几种方法来处理 JWT 的吊销问题:

  1. 黑名单: 维护一个已吊销 JWT 的黑名单。 在验证 JWT 时,检查它是否在黑名单中。
  2. 缩短有效期: 缩短 JWT 的有效期,并使用刷新令牌来获取新的 JWT。
  3. 令牌存储: 将 JWT 存储在服务器端,并在验证时检查其有效性。 这实际上将 JWT 变成了一个会话令牌。

选择哪种方法取决于你的安全需求和性能考虑。 黑名单方法简单易用,但可能会影响性能。 缩短有效期可以减少风险,但会增加令牌刷新的频率。 令牌存储方法提供了最高的安全性,但会增加服务器端的存储和处理负担。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

151

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

176

2023.12.20

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1942

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2117

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1157

2024.11.28

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6535

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

840

2023.09.14

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 4万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.6万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 94人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号