获取标准授权码

用户访问第三方应用时,第三方应用向竹云IDaaS发起授权登录请求,用户输入用户密码认证成功后,竹云IDaaS将重定向到第三方应用,并且带上授权码code参数。

# 请求说明

GET https://{your_domain}/api/v1/oauth2/authorize

# 请求头

# 请求示例

GET https://{your_domain}/api/v1/oauth2/authorize?response_type=code&client_id={client_id}&redirect_uri=http://oauthdemo.bccastle.com/demo/index.jsp&state=123456

# 请求参数

参数名 中文名称 必须 示例值 描述
response_type 授权类型 必须 code 此值固定为code
client_id 应用标识 必须 RqB2676qA 申请接入后分配给第三方应用的clientid。
redirect_uri 回调地址 可选 http://oauthdemo.bccastle.com
/demo/index.jsp
授权后的回调地址,
必须是注册应用时填写的可信域名一致,
注意需要将url进行URLEncode。
state 应用端的状态码 可选 15924362 client端状态值。用于防止CSRF攻击,
成功授权后回调时会原样带回。
请检查用户与state状态绑定。
scope 适用范围 可选 get_user_info 此值固定为get_user_info

# 返回示例

正确返回示例
HTTP Status: 302 REDIRECT
http://oauthdemo.bccastle.com/demo/index.jsp?code=a2WskPcoue0ymFh0B8Q&state=123456


client_id参数缺失
HTTP Status: 400 BAD REQUEST 
 {
  "error": "invalid_request",
  "error_description": "Missing client_id"
}

client_id参数不正确
HTTP Status: 400 BAD REQUEST 
{
  "error": "invalid_request",
  "error_description": "client_id parameter is error"
}

response_type参数名称、值错误
HTTP Status: 400 BAD REQUEST 
{
  "error": "unsupported_response_type",
  "error_description": "Unsupported response types: [xxx]"
}

redirect_uri参数不正确
HTTP Status: 400 BAD REQUEST {
  "error": "invalid_request",
  "error_description": "Invalid redirect: https://www.baidu.com does not match one of the registered values."
}

scope参数不正确
HTTP Status: 302 
{redirect_uri}?error=invalid_scope&error_description=Invalid scope: xxx&state=123456
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
32
33
34
35

# 返回参数

如果用户成功登录并授权,则会跳转到指定的回调地址,并在redirect_uri地址后带上Authorization Code和原始的state值。

参数名 中文名称 必须 示例值 描述
code 授权码 必须 stRWlW 用户登录并授权后,授权服务器返回给应用的授权码。
注意:此code有效期5分钟,有效期内只能使用一次。
state 应用端的状态码 可选 15924362 client端的状态值。用于第三方应用防止CSRF攻击,
成功授权后回调时会原样带回。