令牌解除
登出当前已登录账户的 API。
URL 确认
此 API 使用 service-account.playnanoo.com 域名。
API 信息
- URL:
https://service-account.playnanoo.com/api/v20240401/token/signout - Method:
PUT - 需要认证: 是
请求参数
| 参数 | 类型 | 必需 | 说明 |
|---|---|---|---|
| platform | string | 必需 | 平台(例如:"aos"、"ios") |
| device_id | string | 必需 | 设备唯一 ID |
| device_model | string | 必需 | 设备型号 |
| device_os | string | 必需 | 设备 OS |
| device_language | string | 必需 | 设备语言(例如:"KO"、"EN") |
DeviceInfo 继承
此 API 的 Req 类继承自 DeviceInfo。DeviceInfo 的所有属性将自动包含。
响应数据
Res 类
| 字段 | 类型 | 说明 |
|---|---|---|
| Status | string | 状态值 |
Unity C# 实现
BaseResponse 类
所有 API 响应的基类。
public class BaseResponse
{
public string ErrorCode;
public string Message;
public string WithdrawalKey;
public string BlockKey;
}
字段说明:
ErrorCode:错误代码Message:错误信息WithdrawalKey:处于注销宽限期时恢复所需的密钥(仅在注销宽限期内的账户提供)BlockKey:被封禁账户时提供的密钥(仅在被封禁的账户提供)
登出类
using System;
using System.Collections;
using UnityEngine.Networking;
public class TokenSignOut
{
static string path = "https://service-account.playnanoo.com/api/v20240401/token/signout";
[Serializable]
public class Req : DeviceInfo
{
public IEnumerator Send(
Action<Res> onSuccess,
Action<BaseResponse> onError)
{
yield return HttpClient.Send<Req, Res>(
UnityWebRequest.kHttpVerbPUT,
path,
requireToken: true,
body: this,
onSuccess: onSuccess,
onError: onError
);
}
}
[Serializable]
public class Res : BaseResponse
{
public string Status;
}
}
使用示例
public void SignOut()
{
TokenSignOut.Req req = new TokenSignOut.Req();
StartCoroutine(req.Send(
onSuccess: res =>
{
Debug.Log($"로그아웃 성공: {res.Status}");
// 删除本地存储的令牌
PlayerPrefs.DeleteKey("AccessToken");
PlayerPrefs.DeleteKey("RefreshToken");
PlayerPrefs.Save();
},
onError: (error) =>
{
Debug.LogError($"로그아웃 실패: [{error.ErrorCode}] [{error.Message}]");
}
));
}
登出后处理
登出成功时建议删除本地存储的访问令牌和刷新令牌。