2023-02-10 16:09:39 +00:00
|
|
|
|
# OIDC
|
2023-06-19 13:13:03 +00:00
|
|
|
|
提供标准Open ConnectID接入登录功能。
|
|
|
|
|
本插件登录流程使用**授权码模式 (Authorization Code Flow)**.
|
2023-02-10 16:09:39 +00:00
|
|
|
|
|
2023-06-19 13:13:03 +00:00
|
|
|
|
## 依赖
|
|
|
|
|
- `@nocobase/plugin-auth` 提供表,模型函数复用等
|
2023-02-10 16:09:39 +00:00
|
|
|
|
|
2023-06-19 13:13:03 +00:00
|
|
|
|
## 使用方法
|
|
|
|
|
> 以Sign in with Google为例
|
|
|
|
|
> https://developers.google.com/identity/openid-connect/openid-connect
|
2023-02-10 16:09:39 +00:00
|
|
|
|
|
2023-06-19 13:13:03 +00:00
|
|
|
|
### 获取Google OAuth 2.0凭据
|
|
|
|
|
[Google Cloud控制台](https://console.cloud.google.com/apis/credentials) - 创建凭据 - OAuth客户端ID
|
2023-02-10 16:09:39 +00:00
|
|
|
|
|
2023-06-19 13:13:03 +00:00
|
|
|
|
<img src="https://s2.loli.net/2023/06/19/8KPGut6noqgBlDL.png"/>
|
|
|
|
|
|
|
|
|
|
进入到配置界面,填写**授权重定向URL**. 重定向URL可以在Nocobase,新增认证器时获取,通常情况下为`http(s)://host:port/api/oidc:redirect`.
|
|
|
|
|
|
|
|
|
|
<img src="https://s2.loli.net/2023/06/19/cB1Mv3SAOa7H6Vb.png"/>
|
|
|
|
|
|
|
|
|
|
完成后复制**客户端ID**和**客户端密钥**。
|
|
|
|
|
|
2023-06-19 13:32:16 +00:00
|
|
|
|
### 在NocoBase上新增认证器
|
2023-06-19 13:13:03 +00:00
|
|
|
|
插件设置 - 认证 - 新增 - OIDC
|
|
|
|
|
|
|
|
|
|
<img src="https://s2.loli.net/2023/06/19/sBMURatC372GyEd.png"/>
|
|
|
|
|
依次填写
|
|
|
|
|
|
|
|
|
|
- Issuer - issuer由IdP提供,通常以`/.well-known/openid-configuration`结尾,Google的为[https://accounts.google.com/.well-known/openid-configuration](https://accounts.google.com/.well-known/openid-configuration)
|
|
|
|
|
- Client ID - 客户端ID
|
|
|
|
|
- Client Secret - 客户端密钥
|
|
|
|
|
- scope - 选填,默认为openid email profile
|
|
|
|
|
- id_token signed response algorithm - id_token的签名方法,默认为RS256
|
|
|
|
|
- HTTP - 回调地址是否为http协议,默认https
|
|
|
|
|
- Port - 回调地址端口,默认为443/80
|
|
|
|
|
- Field Map - 如果需要将用户相关字段映射,可以在这里配置,默认昵称为openid.
|
|
|
|
|
|
2023-06-19 13:32:16 +00:00
|
|
|
|
在有email的情况下,登录时将尝试匹配已有用户,否则创建新用户。
|