2023-06-17 05:36:05 +00:00
|
|
|
|
# 用户Token
|
|
|
|
|
|
|
|
|
|
- [Token](#token)
|
|
|
|
|
- [通过Login Ticket获取SToken和LToken](#通过login-ticket获取stoken和ltoken)
|
|
|
|
|
- [通过SToken获取Cookie Token](#通过stoken获取cookie-token)
|
|
|
|
|
- [通过Game Token获取SToken](#通过game-token获取stoken)
|
|
|
|
|
- [通过Game Token获取Cookie Token](#通过game-token获取cookie-token)
|
|
|
|
|
- [通过Cookie Token获取Hk4e Token](#通过cookie-token获取hk4e-token)
|
|
|
|
|
- [Auth Key](#auth-key)
|
|
|
|
|
- [通过SToken获取用户Auth Key A](#通过stoken获取账号auth-key-a)
|
|
|
|
|
- [通过SToken获取用户Auth Key B](#通过stoken获取账号auth-key-b)
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Token
|
|
|
|
|
|
|
|
|
|
### 通过Login Ticket获取SToken和LToken
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:GET_
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.mihoyo.com/auth/api/getMultiTokenByLoginTicket`
|
|
|
|
|
|
|
|
|
|
**参数:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| token_types | num | 获取的Token的类型<br>1 仅SToken<br>2 仅LToken<br>3 SToken和LToken<br>4 无 | |
|
|
|
|
|
| login_ticket | str | 有效的Login Ticket | |
|
|
|
|
|
| uid | num | 对应的米游社账号UID | |
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| retcode | num | 返回码 | |
|
|
|
|
|
| message | str | 返回消息 | |
|
|
|
|
|
| data | obj | Token | |
|
|
|
|
|
|
|
|
|
|
`data`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| list | arr | SToken或LToken | |
|
|
|
|
|
|
|
|
|
|
`data`对象→`list`数组→对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| name | str | Token类型<br>ltoken LToken<br>stoken SToken | |
|
|
|
|
|
| token | str | Token值 | |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
|
|
|
|
"list": [
|
|
|
|
|
{
|
|
|
|
|
"name": "stoken",
|
|
|
|
|
"token": "***"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
"name": "ltoken",
|
|
|
|
|
"token": "***"
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
### 通过SToken获取Cookie Token
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:GET_
|
|
|
|
|
|
|
|
|
|
> _需要验证Cookie_
|
|
|
|
|
>
|
|
|
|
|
> SToken
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.mihoyo.com/auth/api/getCookieAccountInfoBySToken`
|
|
|
|
|
|
|
|
|
|
**参数:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| stoken | str | 有效的SToken | |
|
|
|
|
|
| uid | num | 对应的米游社账号UID | |
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| retcode | num | 返回码 | |
|
|
|
|
|
| message | str | 返回消息 | |
|
|
|
|
|
| data | obj | Cookie Token和米游社UID | |
|
|
|
|
|
|
|
|
|
|
`data`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| uid | str | 米游社UID | |
|
|
|
|
|
| cookie_token | str | SToken对应账号的Cookie Token | |
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
|
|
|
|
"uid": "***",
|
|
|
|
|
"cookie_token": "***"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
### 通过Game Token获取SToken
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:POST_
|
|
|
|
|
|
|
|
|
|
> _需要验证请求头_
|
|
|
|
|
>
|
|
|
|
|
> `x-rpc-app_id`
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.mihoyo.com/account/ma-cn-session/app/getTokenByGameToken`
|
|
|
|
|
|
|
|
|
|
**JSON请求:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| account_id | num | 对应的米游社账号UID | |
|
|
|
|
|
| game_token | str | 有效的Game Token | |
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| retcode | num | 返回码<br>-3005 未传递`x-rpc-app_id`请求头 | |
|
|
|
|
|
| message | str | 返回消息 | |
|
|
|
|
|
| data | obj | 账号的Token与隐私信息 | |
|
|
|
|
|
|
|
|
|
|
`data`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| token | obj | 米游社账号的SToken | |
|
|
|
|
|
| user_info | obj | 米游社账号敏感信息 | 一些个人信息已被隐藏 |
|
|
|
|
|
| realname_info | | 待调查 | |
|
|
|
|
|
| need_realperson | bool | 待调查 | |
|
|
|
|
|
|
|
|
|
|
`data`对象→`token`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| token_type | num | 1 | |
|
|
|
|
|
| token | str | 账号的SToken | |
|
|
|
|
|
|
|
|
|
|
`data`对象→`user_info`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| aid | str | 米游社UID | |
|
|
|
|
|
| mid | str | 米游社MiHoYo ID | |
|
|
|
|
|
| account_name | str | 空字符串 | |
|
|
|
|
|
| email | str | 被隐藏的账号的绑定邮箱 | |
|
|
|
|
|
| is_email_verify | num | 绑定邮箱是否通过验证 | |
|
|
|
|
|
| area_code | str | 账号绑定手机的区号 | |
|
|
|
|
|
| mobile | str | 被隐藏的账号的绑定手机 | |
|
|
|
|
|
| safe_area_code | str | 账号安全手机的区号 | 历史遗留字段,现在安全手机的功能已经被移除了 |
|
|
|
|
|
| safe_mobile | str | 被隐藏的账号安全手机 | 历史遗留字段,现在安全手机的功能已经被移除了 |
|
|
|
|
|
| realname | str | 被隐藏的账号实名认证姓名 | |
|
|
|
|
|
| identity_code | str | 被隐藏的账号实名认证身份证号 | |
|
|
|
|
|
| rebind_area_code | str | 账号的换绑手机号的区号 | |
|
|
|
|
|
| rebind_mobile | str | 被隐藏的账号的换绑手机号 | |
|
|
|
|
|
| rebind_mobile_time | str | 0 | |
|
|
|
|
|
| links | arr | 待调查 | |
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
|
|
|
|
"token": {
|
|
|
|
|
"token_type": 1,
|
|
|
|
|
"token": "***"
|
|
|
|
|
},
|
|
|
|
|
"user_info": {
|
|
|
|
|
"aid": "*******",
|
|
|
|
|
"mid": "*******",
|
|
|
|
|
"account_name": "",
|
|
|
|
|
"email": "*********",
|
|
|
|
|
"is_email_verify": 1,
|
|
|
|
|
"area_code": "+86",
|
|
|
|
|
"mobile": "***********",
|
|
|
|
|
"safe_area_code": "",
|
|
|
|
|
"safe_mobile": "",
|
|
|
|
|
"realname": "***",
|
|
|
|
|
"identity_code": "******************",
|
|
|
|
|
"rebind_area_code": "",
|
|
|
|
|
"rebind_mobile": "",
|
|
|
|
|
"rebind_mobile_time": "0",
|
|
|
|
|
"links": []
|
|
|
|
|
},
|
|
|
|
|
"realname_info": null,
|
|
|
|
|
"need_realperson": false
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
### 通过Game Token获取Cookie Token
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:GET_
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.mihoyo.com/auth/api/getCookieAccountInfoByGameToken`
|
|
|
|
|
|
|
|
|
|
**参数:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| account_id | num | 对应的米游社账号UID | |
|
|
|
|
|
| game_token | str | 有效的Game Token | |
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
与[通过SToken获取Cookie Token](#通过stoken获取cookie-token)→根对象的结构相同。
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
2023-06-17 05:42:51 +00:00
|
|
|
|
"uid": "***",
|
|
|
|
|
"cookie_token": "***"
|
2023-06-17 05:36:05 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
### 通过Cookie Token获取Hk4e Token
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:POST_
|
|
|
|
|
|
|
|
|
|
> _需要验证Cookie_
|
|
|
|
|
>
|
|
|
|
|
> Account ID:`account_id`
|
|
|
|
|
>
|
|
|
|
|
> Cookie Token:`cookie_token`
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.mihoyo.com/auth/api/getCookieAccountInfoByGameToken`
|
|
|
|
|
|
|
|
|
|
**参数:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| account_id | num | 对应的米游社账号UID | |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
|
|
|
|
"game": "hk4e",
|
|
|
|
|
"region": "cn_gf01",
|
|
|
|
|
"game_uid": "222681079",
|
|
|
|
|
"game_biz": "hk4e_cn",
|
|
|
|
|
"level": 58,
|
|
|
|
|
"nickname": "※青衫入雨※",
|
|
|
|
|
"region_name": "天空岛"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
## Auth Key
|
|
|
|
|
|
|
|
|
|
### 通过SToken获取账号Auth Key A
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:POST_
|
|
|
|
|
|
|
|
|
|
> _需要验证Cookie_
|
|
|
|
|
>
|
|
|
|
|
> SToken
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.miyoushe.com/account/auth/api/genAuthKey`
|
|
|
|
|
|
|
|
|
|
**JSON请求:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| game_biz | str | 米游社区域<br>bbs_cn 国服 | |
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| retcode | num | 返回码<br>1002 请求体的`game_biz`字段不正确 | |
|
|
|
|
|
| message | str | 返回消息 | |
|
|
|
|
|
| data | obj | Auth Key A | |
|
|
|
|
|
|
|
|
|
|
`data`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| sign_type | num | 2 | |
|
|
|
|
|
| authkey_ver | num | 1 | |
|
|
|
|
|
| authkey | str | Auth Key A | |
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
|
|
|
|
"sign_type": 2,
|
|
|
|
|
"authkey_ver": 1,
|
|
|
|
|
"authkey": "***"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
**国际服:**
|
|
|
|
|
|
|
|
|
|
`未知`
|
|
|
|
|
|
|
|
|
|
### 通过SToken获取账号Auth Key B
|
|
|
|
|
|
|
|
|
|
用例:获取用户的游戏抽卡记录等API需要使用到Auth Key B。
|
|
|
|
|
|
|
|
|
|
**国服:**
|
|
|
|
|
|
|
|
|
|
_请求方式:POST_
|
|
|
|
|
|
|
|
|
|
> _需要验证请求头_
|
|
|
|
|
>
|
|
|
|
|
> `x-rpc-client_type`:`2`
|
|
|
|
|
>
|
|
|
|
|
> LK`salt`
|
|
|
|
|
>
|
|
|
|
|
> `DS1`
|
|
|
|
|
|
|
|
|
|
> _需要验证Cookie_
|
|
|
|
|
>
|
|
|
|
|
> SToken
|
|
|
|
|
|
|
|
|
|
`https://api-takumi.miyoushe.com/binding/api/genAuthKey`
|
|
|
|
|
<!--`https://hk4e-sdk.mihoyo.com/hk4e_cn/combo/granter/login/genAuthKey`-->
|
|
|
|
|
|
|
|
|
|
**JSON请求:**
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| game_biz | str | 获取的`authkey`B的游戏<br>hk4e_cn 《原神》国服<br>hkrpg_cn 《崩坏:星穹铁道》国服<br> | |
|
|
|
|
|
| game_uid | num | 用户的游戏UID | |
|
|
|
|
|
|
|
|
|
|
**JSON返回:**
|
|
|
|
|
|
|
|
|
|
根对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| retcode | num | 返回码<br>1002 请求体的`game_biz`字段不正确 | |
|
|
|
|
|
| message | str | 返回消息 | |
|
|
|
|
|
| data | obj | Auth Key B | |
|
|
|
|
|
|
|
|
|
|
`data`对象:
|
|
|
|
|
|
|
|
|
|
| 字段 | 类型 | 内容 | 备注 |
|
|
|
|
|
| ---- | ---- | ---- | ---- |
|
|
|
|
|
| sign_type | num | 2 | |
|
|
|
|
|
| authkey_ver | num | 1 | |
|
|
|
|
|
| authkey | str | Auth Key B | |
|
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>查看示例</summary>
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"retcode": 0,
|
|
|
|
|
"message": "OK",
|
|
|
|
|
"data": {
|
|
|
|
|
"sign_type": 2,
|
|
|
|
|
"authkey_ver": 1,
|
|
|
|
|
"authkey": "***"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
**国际服:**
|
|
|
|
|
|
|
|
|
|
`未知`
|