SpringBoot集成OAuth2.0

news2025/4/11 4:44:45

文章目录

      • OAuth 2.0 介绍
        • 概念
        • 与传统认证方式的对比
        • 常见应用场景
      • OAuth 2.0 原理
        • 核心角色
        • 授权流程
      • Spring Boot 集成 OAuth 2.0
        • 1. 添加依赖
        • 2. 配置 OAuth 2.0 客户端
        • 3. 配置 Spring Security
        • 4. 创建控制器
        • 5. 主应用类
      • 代码解释

OAuth 2.0 介绍

概念

OAuth 2.0 是一个开放标准的授权协议,它允许用户授权第三方应用访问其在另一个服务提供商处存储的受保护资源,而无需将自己的用户名和密码直接提供给第三方应用。这极大地增强了用户数据的安全性和隐私性,广泛应用于各种需要第三方授权访问的场景,如社交登录、第三方应用获取用户在云存储服务中的文件等。

与传统认证方式的对比
  • 传统认证方式:通常要求用户直接向第三方应用提供其在服务提供商处的用户名和密码,这存在密码泄露的风险。一旦第三方应用的安全性出现问题,用户的账户信息将面临严重威胁。
  • OAuth 2.0:用户只需在服务提供商的授权页面上进行授权操作,第三方应用获得的是访问令牌(Access Token),而非用户的原始凭据。即使令牌泄露,攻击者也只能在令牌的有效期和权限范围内访问资源,且令牌可以被服务提供商随时撤销。
常见应用场景
  • 社交登录:许多网站和应用允许用户使用社交媒体账号(如微信、QQ、微博、Google、Facebook 等)进行登录。用户无需在新平台上注册新账号,只需授权平台访问其社交账号的基本信息,即可快速完成登录。
  • 第三方数据访问:例如,一个健身应用可以请求用户授权访问其在运动追踪服务提供商处的运动数据,以便为用户提供更全面的健身分析和建议。
  • API 访问:开发者在开发第三方应用时,需要调用某些服务提供商的 API 来获取数据或执行操作。通过 OAuth 2.0 授权,开发者可以在不暴露用户敏感信息的情况下,合法地使用这些 API。

OAuth 2.0 原理

核心角色
  • 资源所有者(Resource Owner):一般是用户,拥有受保护的资源,并有权决定是否授权第三方应用访问这些资源。例如,用户在 Facebook 上的个人信息和照片就是受保护资源,用户可以决定是否允许某个第三方游戏应用访问这些信息。
  • 资源服务器(Resource Server):存储受保护资源的服务器。它负责验证访问令牌的有效性,并在验证通过后向第三方应用提供相应的资源。例如,Facebook 的服务器存储了用户的个人信息和照片,当第三方应用携带有效的访问令牌请求这些资源时,Facebook 的服务器会进行验证并返回数据。
  • 客户端(Client):即第三方应用,希望访问用户的受保护资源。客户端需要先获得用户的授权,然后使用授权服务器颁发的访问令牌来访问资源服务器上的资源。例如,上述的第三方游戏应用就是客户端。
  • 授权服务器(Authorization Server):负责验证资源所有者的身份,处理授权请求,并发放访问令牌。它与资源所有者进行交互,确认用户是否同意授权给客户端,并在用户授权后生成并返回访问令牌。例如,Facebook 的授权服务器会验证用户的身份,显示授权页面,当用户点击“同意”后,生成访问令牌并返回给客户端。
授权流程

OAuth 2.0 定义了四种授权模式,下面详细介绍最常用的授权码模式(Authorization Code Grant):

  1. 客户端请求授权:客户端引导用户到授权服务器的授权端点,请求用户授权。请求中包含客户端 ID、重定向 URI、请求的权限范围等信息。例如,当用户在第三方游戏应用中选择使用 Facebook 账号登录时,应用会将用户重定向到 Facebook 的授权页面,并携带应用的客户端 ID、指定的重定向 URI 以及请求的权限范围(如获取用户的基本信息、好友列表等)。
  2. 用户授权:用户在授权服务器的页面上登录并确认是否授权给客户端访问其资源。例如,用户在 Facebook 的授权页面上输入自己的账号密码登录后,会看到一个授权提示,显示第三方应用请求的权限范围,用户可以选择“同意”或“拒绝”。
  3. 授权服务器返回授权码:如果用户授权,授权服务器将用户重定向回客户端指定的重定向 URI,并附带一个授权码(Authorization Code)。授权码是一个临时的、一次性的代码,用于后续换取访问令牌。例如,用户点击“同意”后,Facebook 的授权服务器会将用户重定向回第三方游戏应用指定的重定向 URI,并在 URL 中附带授权码。
  4. 客户端换取访问令牌:客户端使用接收到的授权码向授权服务器的令牌端点发送请求,同时提供客户端 ID 和客户端密钥进行身份验证。授权服务器验证通过后,返回访问令牌(Access Token)和可选的刷新令牌(Refresh Token)。例如,第三方游戏应用接收到授权码后,会向 Facebook 的令牌端点发送请求,携带授权码、客户端 ID 和客户端密钥,Facebook 的授权服务器验证这些信息无误后,会返回访问令牌和可能的刷新令牌。
  5. 客户端访问资源:客户端使用访问令牌向资源服务器发送请求,资源服务器验证令牌的有效性,验证通过后返回受保护的资源。例如,第三方游戏应用使用接收到的访问令牌向 Facebook 的资源服务器请求用户的基本信息,资源服务器验证令牌有效后,会返回用户的姓名、头像等信息。

Spring Boot 集成 OAuth 2.0

1. 添加依赖

pom.xml 中添加以下依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-oauth2-client</artifactId>
    </dependency>
</dependencies>
2. 配置 OAuth 2.0 客户端

application.yml 中配置 OAuth 2.0 客户端信息,以 GitHub 为例:

spring:
  security:
    oauth2:
      client:
        registration:
          github:
            client-id: your-client-id
            client-secret: your-client-secret
            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

your-client-idyour-client-secret 替换为你在 GitHub 开发者设置中创建的实际客户端 ID 和客户端密钥。

3. 配置 Spring Security

创建一个配置类来配置 Spring Security 以支持 OAuth 2.0 登录:

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.web.SecurityFilterChain;

@Configuration
public class SecurityConfig {

    @Bean
    public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
        http
           .authorizeRequests()
               .anyRequest().authenticated()
               .and()
           .oauth2Login();
        return http.build();
    }
}
4. 创建控制器

创建一个简单的控制器来测试 OAuth 2.0 登录后的访问:

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HomeController {

    @GetMapping("/")
    public String home() {
        return "Welcome to the protected area! You are authenticated.";
    }
}
5. 主应用类
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class SpringBootOauth2DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringBootOauth2DemoApplication.class, args);
    }
}

代码解释

  • 依赖部分:添加了 spring-boot-starter-webspring-boot-starter-oauth2-client 依赖,为项目提供 Web 服务和 OAuth 2.0 客户端支持。
  • 配置文件:在 application.yml 中配置了 GitHub 的 OAuth 2.0 客户端信息,包含客户端 ID、客户端密钥、授权 URI、令牌 URI 以及用户信息 URI 等。
  • SecurityConfig 类:对 Spring Security 进行配置,要求所有请求都需经过身份验证,并启用 OAuth 2.0 登录。
  • HomeController 类:提供一个简单的端点 /,只有经过身份验证的用户才能访问。
  • 主应用类:启动 Spring Boot 应用。

按照上述步骤操作,就能在 Spring Boot 项目中集成 OAuth 2.0 认证。启动应用后,访问项目根路径,会自动跳转到 GitHub 的授权页面,授权成功后即可访问受保护的资源。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2328110.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《继电器:机械骑士的电磁战甲》

点击下面图片带您领略全新的嵌入式学习路线 &#x1f525;爆款热榜 88万阅读 1.6万收藏 第一章&#xff1a;千年契约的青铜誓言 在电气王国的熔炉深处&#xff0c;电磁铁与簧片的盟约已镌刻千年。电磁铁身披螺旋铜线编织的斗篷&#xff0c;其胸膛中沉睡着一道可召唤磁力的古…

快速求平方根

1. 前置知识 建议首先阅读我的另外一篇文章《雷神之锤 III 竞技场》快速求平方根倒数的计算探究》。建议大家自己看过《雷神之锤 III 竞技场》快速求平方根倒数的计算探究》学会快速求平方根倒数算法后&#xff0c;不看我这篇文章&#xff0c;自己推导一篇快速求平方根的算法&…

C语言基础要素(019):输出ASCII码表

计算机以二进制处理信息&#xff0c;但二进制对人类并不友好。比如说我们规定用二进制值 01000001 表示字母’A’&#xff0c;显然通过键盘输入或屏幕阅读此数据而理解它为字母A&#xff0c;是比较困难的。为了有效的使用信息&#xff0c;先驱者们创建了一种称为ASCII码的交换代…

CI/CD(九) Jenkins共享库与多分支流水线准备

后端构建 零&#xff1a;安装插件 Pipeline: Stage View&#xff08;阶段视图&#xff09;、SSH Pipeline Steps&#xff08;共享库代码中要调用sshCommond命令&#xff09; 一、上传共享库 二、Jenkins配置共享库 3、新增静态资源与修改配置 如果是docker和k8s启动&#xf…

pip安装timm依赖失败

在pycharm终端给虚拟环境安装timm库失败&#xff08; pip install timm&#xff09;&#xff0c;提示你要访问 https://rustup.rs/ 来下载并安装 Rust 和 Cargo 直接不用管&#xff0c;换一条命令 pip install timm0.6.13 成功安装 简单粗暴

详解隔离级别(4种),分别用表格展示问题出现的过程及解决办法

选择隔离级别的时候&#xff0c;既需要考虑数据的一致性&#xff0c;避免脏数据&#xff0c;又要考虑系统性能的问题。下面我们通过商品抢购的场景来讲述这4种隔离级别的区别 未提交读&#xff08;read uncommitted&#xff09; 未提交读是最低的隔离级别&#xff0c;其含义是…

NO.63十六届蓝桥杯备战|基础算法-⼆分答案|木材加工|砍树|跳石头(C++)

⼆分答案可以处理⼤部分「最⼤值最⼩」以及「最⼩值最⼤」的问题。如果「解空间」在从⼩到⼤的「变化」过程中&#xff0c;「判断」答案的结果出现「⼆段性」&#xff0c;此时我们就可以「⼆分」这个「解空间」&#xff0c;通过「判断」&#xff0c;找出最优解。 这个「⼆分答案…

深层储层弹塑性水力裂缝扩展机理

弹性与弹塑性储层条件下裂缝形态对比 参考&#xff1a; The propagation mechanism of elastoplastic hydraulic fracture in deep reservoir | International Journal of Coal Science & Technology

循环神经网络 - 机器学习任务之异步的序列到序列模式

前面我们学习了机器学习任务之同步的序列到序列模式&#xff1a;循环神经网络 - 机器学习任务之同步的序列到序列模式-CSDN博客 本文我们来学习循环神经网络应用中的第三种模式&#xff1a;异步的序列到序列模式&#xff01; 一、基本概述&#xff1a; 异步的序列到序列模式…

什么是检索增强生成(RAG)

1、什么是检索增强生成&#xff08;RAG&#xff09; 1.1 检索增强生成的概念 检索增强生成&#xff08;Retrieval-Augmented Generation, RAG&#xff09;是一种结合了信息检索和文本生成技术的新型自然语言处理方法。这种方法增强了模型的理解和生成能力。 相较于经典生成…

MATLAB 控制系统设计与仿真 - 33

状态反馈控制系统 -全维状态观测器的实现 状态观测器的建立解决了受控系统不能测量的状态重构问题&#xff0c;使得状态反馈的工程实现成为可能。 考虑到系统的状态方程表达式&#xff0c;如果{A,B}可控&#xff0c;{A,C}可观&#xff0c;且安装系统的性能指标&#xff0c;可…

企业管理系统的功能架构设计与实现

一、企业管理系统的核心功能模块 企业管理系统作为现代企业的中枢神经系统&#xff0c;涵盖了多个核心功能模块&#xff0c;以确保企业运营的顺畅与高效。这些功能模块通常包括&#xff1a; 人力资源管理模块&#xff1a;负责员工信息的录入、维护、查询及统计分析&#xff0c…

覆盖学术、职场、生活的专业计算工具

软件介绍 今天要给大家介绍一款超给力的工具软件——CalcKit 计算器。它就像是你口袋里的智能计算专家&#xff0c;轻松化解日常生活中的各类计算难题。无论是简单的数字加减乘除&#xff0c;还是复杂的专业运算&#xff0c;它都不在话下。 这款软件内置了极为强大的计算功能…

【大模型系列篇】大模型基建工程:基于 FastAPI 自动构建 SSE MCP 服务器 —— 进阶篇

&#x1f525;&#x1f525;&#x1f525; 上期 《大模型基建工程&#xff1a;基于 FastAPI 自动构建 SSE MCP 服务器》中我们使用fastapi-mcp自动挂载fastapi到mcp工具&#xff0c;通过源码分析和实践&#xff0c;我们发现每次sse请求又转到了内部fastapi RESTful api接口&…

【python】Plot a Square

文章目录 1、功能描述2、代码实现3、效果展示4、完整代码5、涉及到的库函数 更多有趣的代码示例&#xff0c;可参考【Programming】 1、功能描述 用 python 实现&#xff0c;以 A和B两个点为边长&#xff0c;方向朝 C 绘制正方形 思路&#xff1a; 计算向量 AB 和 AC。使用向…

实战打靶集锦-37-Wpwnvm

文章目录 1. 主机发现2. 端口扫描&服务枚举3. 服务探查4. 系统提权 靶机地址&#xff1a;https://download.vulnhub.com/wpwn/wpwnvm.zip 1. 主机发现 目前只知道目标靶机在192.168.37.xx网段&#xff0c;通过如下的命令&#xff0c;看看这个网段上在线的主机。 $ nmap -…

三、GPIO

一、GPIO简介 GPIO&#xff08;General Purpose Input Output&#xff09;通用输入输出口GPIO引脚电平&#xff1a;0V&#xff08;低电平&#xff09;~3.3V&#xff08;高电平&#xff09;&#xff0c;部分引脚可容忍5V 容忍5V&#xff0c;即部分引脚输入5V的电压&#xff0c;…

混杂模式(Promiscuous Mode)与 Trunk 端口的区别详解

一、混杂模式&#xff08;Promiscuous Mode&#xff09; 1. 定义与工作原理 定义&#xff1a;混杂模式是网络接口的一种工作模式&#xff0c;允许接口接收通过其物理链路的所有数据包&#xff0c;而不仅是目标地址为本机的数据包。工作层级&#xff1a;OSI 数据链路层&#x…

[dp5_多状态dp] 按摩师 | 打家劫舍 II | 删除并获得点数 | 粉刷房子

目录 1.面试题 17.16. 按摩师 题解 2.打家劫舍 II 题解 3.删除并获得点数 题解 4.粉刷房子 题解 一定要有这样的能力&#xff0c;碰到一个新题的时候&#xff0c;可以往之前做过的题方向靠&#xff01; 打家劫舍问题模型: 不能选择相邻的两个数&#xff0c;并且要最终…

DM数据库配置归档模式的两种方式

归档模式&#xff0c;联机日志文件中的内容保存到硬盘中&#xff0c;形成归档日志文件(REDO日志)。 采用归档模式会对系统的性能产生些许影响&#xff0c;然而系统在归档模式下运行会更安全&#xff0c;当 出现故障时其丢失数据的可能性更小&#xff0c;这是因为一旦出现介质故…