## 😄Spring Authorization Server (3) 集成第三方【gitee、github】登录

建议集成gitee即可,github的网络请求不太稳定,梯子可能也会出现不稳定的情况

github集成

1. 在github中创建一个oauth应用

2. demo-authorizationserver 的授权服务器配置

  • 添加oauth配置

    yaml 复制代码
    spring:
      security:
        oauth2:
          client:
            registration:
              github: # 这个唯一就可以了 对应的也就是 {registrationId}
                provider: github # 换个对应如下的 provider
                client-id: 2205af0f0cc93e3a22ea #刚刚创建应用的client-id
                client-secret: 649d88df840a57d2591c4832b438cc9af2727240 #刚刚创建应用的client-secret
                redirect-uri: http://localhost:9000/login/oauth2/code/github # 模板 `{baseUrl}/login/oauth2/code/{registrationId}`
                scope: user:email, read:user #这个可以参考文档根据需要修改
                client-name: Sign in with GitHub
    
            provider:
              github:
                user-name-attribute: login

3. demo 示例

  • 我们现在访问客户端的主页:127.0.0.1:8080/index时,浏览器会重定向到:http://localhost:9000/login

  • 使用github登录

  • 我们自己的授权服务进行授权

  • 客户端成功访问

  • 客户端成功访问资源服务

gitee集成

1. 在gitee中创建一个第三方应用

  • 步骤如下

    • 找到gitee创建第三方应用的这个位置
    • 创建应用

2. demo-authorizationserver 的授权服务器配置

yaml 复制代码
spring:
  security:
    oauth2:
      client:
        registration:
          gitee:
            # 指定oauth登录提供者,该oauth登录由provider中的gitee来处理
            provider: gitee
            # 客户端名字
            client-name: Sign in with Gitee
            # 认证方式
            authorization-grant-type: authorization_code
            # 客户端id,使用自己的gitee的客户端id
            client-id: 29b85c97ed682910eaa4276d84a0c4532f00b962e1b9fe8552520129e65ae432
            # 客户端秘钥,使用自己的gitee的客户端秘钥
            client-secret: 8c6df920482a83d4662a34b76a9c3a62c8e80713e4f2957bb0459c3ceb70d73b
            # 回调地址 与gitee 配置的回调地址一致才行
            redirect-uri: http://192.168.56.1:9000/login/oauth2/code/gitee
            # 申请scope列表
            scope:
              - emails
              - user_info

        provider:
          gitee:
          # 设置用户信息名称对应的字段属性
          user-name-attribute: login
          # 获取token的地址
          token-uri: https://gitee.com/oauth/token
          # 获取用户信息的地址
          user-info-uri: https://gitee.com/api/v5/user
          # 发起授权申请的地址
          authorization-uri: https://gitee.com/oauth/authorize

3. demo示例

总结

  1. http://192.168.56.1:9000/login/oauth2/code/github,是spring-security-oauth2-client提供的一个模板 URL {baseUrl}/login/oauth2/code/{registrationId} , 第三方应用配置的回调调用 对应OAuth2LoginAuthenticationFilter 做后续处理, 在spring-security的源码中通过login/oauth2/code能搜索到 OAuth2LoginAuthenticationFilter

    java 复制代码
    public class OAuth2LoginAuthenticationFilter extends AbstractAuthenticationProcessingFilter {
    
               //The default URI where this Filter processes authentication requests.
               public static final String DEFAULT_FILTER_PROCESSES_URI = "/login/oauth2/code/*";
                ...
               @Override
               public Authentication attemptAuthentication(HttpServletRequest request, HttpServletResponse response)
                       throws AuthenticationException {
                   ...
               }
    
    }
  2. 第三方回调地址 一定要与授权服务器(demo-authorizationserver)的yml中的回调地址一致,否则出现异常。

  3. demo-client的 spring.security.oauth2.client.provider.issuer-uri 配置一定不要与 demo-authorizationserver服务在同一个域下,例如当前demo-client 是 http://127.0.0.1:8080,那么 spring.security.oauth2.client.provider.issuer-urihttp://192.168.56.1:9000,就不要配置 http://127.0.0.1:9000 后面详细有时间再好好讲讲这个的原因(大概就是seesion的原因,未认证请求前,授权服务器会保存客户端的授权请求,一旦授权成功后,就会删除seesion中的授权请求....)。

相关推荐
计算机毕业设计木哥2 小时前
计算机毕业设计选题推荐:基于SpringBoot和Vue的快递物流仓库管理系统【源码+文档+调试】
java·vue.js·spring boot·后端·课程设计
Chan165 小时前
流量安全优化:基于 Sentinel 实现网站流量控制和熔断
java·spring boot·安全·sentinel·intellij-idea·进程
勇往直前plus6 小时前
如何利用docker部署springboot应用
spring boot·docker·容器
ZhengEnCi6 小时前
@RequestParam 注解完全指南-从参数绑定到接口调用的Web开发利器
java·spring boot
=>>漫反射=>>6 小时前
单元测试 vs Main方法调试:何时使用哪种方式?
java·spring boot·单元测试
ZhengEnCi6 小时前
@Parameter 注解技术解析-从 API 文档生成到接口描述清晰的 SpringBoot 利器
java·spring boot
junnhwan8 小时前
【苍穹外卖笔记】Day04--套餐管理模块
java·数据库·spring boot·后端·苍穹外卖·crud
低音钢琴8 小时前
【SpringBoot从初学者到专家的成长15】MVC、Spring MVC与Spring Boot:理解其差异与联系
spring boot·spring·mvc
摇滚侠8 小时前
Spring Boot 3零基础教程,条件注解,笔记09
java·spring boot·笔记
南瓜小米粥、8 小时前
从可插拔拦截器出发:自定义、注入 Spring Boot、到生效路径的完整实践(Demo 版)
java·spring boot·后端