springsecurity oauth2 授权码模式流程

authorization_code

1.客户端站点尝试获取授权码

http://authServer/oauth/authorize?response_type=code&client_id=client_id&redirect_uri=http://clientSite

2.用户认证,输入用户名密码

http://authServer/login

3.OAuth授权,选择授权scope

http://authServer/oauth/authorize?response_type=code&client_id=client_id&redirect_uri=http://clientSite

4.客户端站点获取授权码

http://clientSite/?code=WHV34h

5.客户端站点使用授权码和客户端密码获取token

http://authServer/oauth/token?client_id=client_id&redirect_uri=http://clientSite&code=WHV34h&grant_type=authorization_code&client_secret=password
返回数据格式:

{
    "access_token": "2a04fdc1-32b9-48b7-b748-8d94c25dbcf7",
    "token_type": "bearer",
    "refresh_token": "4090d5ff-a876-4b2b-ab54-7677d2d45ac8",
    "scope": "all"
}

6.客户端使用token访问资源

http://resourceServer/?access_token=2a04fdc1-32b9-48b7-b748-8d94c25dbcf7

7.资源校验token

http://localhost:11000/oauth/check_token
basic auth:
username: client_id
password: password
form-data:
token=2a04fdc1-32b9-48b7-b748-8d94c25dbcf7
返回数据格式

{
    "active": true,
    "user_name": "user",
    "authorities": [
        "ROLE_USER"
    ],
    "client_id": "client_id",
    "scope": [
        "all"
    ]
}

posted on   路过君  阅读(466)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2020-04-11 spring 启动时自动运行
2020-04-11 spring cloud oauth2授权服务 默认tokenService配置源码
2020-04-11 spring cloud 搭建oauth2授权服务 使用redis存储令牌
2020-04-11 spring cloud oauth2授权服务 clientDetails配置源码
2020-04-11 spring 验证框架
2020-04-11 IDEA 插件整理
2020-04-11 spring security笔记 默认登陆页面源码

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示