mirror of
https://github.com/UIGF-org/mihoyo-api-collect.git
synced 2025-12-11 08:38:12 +08:00
2.2 KiB
2.2 KiB
鉴权
部分API需要使用Cookie鉴权。
米游社
大多数API需要验证请求头部的X-rpc-app_version、X-rpc-client_type、X-Requested-With、Origin、Referer、DS、User-Agent、Cookie。
X-rpc-app_version:APP版本,国际版APP与国内版APP版本不一样。国际版APP与国内版APP每个版本对应生成DS所用的salt也不一样。X-rpc-client_type:国内版APP则为5,国际版APP则为2。X-Requested-With:国内版APP则为com.mihoyo.hyperion,国际版APP则为com.mihoyo.hoyolab。Origin:国内版APP则为https://webstatic.mihoyo.com,国际版APP则为https://webstatic-sea.hoyolab.com。Referer:国内版APP则为https://webstatic.mihoyo.com,国际版APP则为https://webstatic-sea.hoyolab.com。DS:见DS值。User-Agent:用户代理,为Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) miHoYoBBS/2.11.1。Cookie:见Cookie
DS值
DS值通过一系列算法得出。
大致步骤如下(伪代码):
salt = APP版本所用的salt
timestamp = 当前Unix时间戳
if 是国服或渠道服 {
random = 随机整数(100001, 200000)
}
else if 是国际服 {
random = 随机6位字母()
}
if 要发送的请求 是 POST请求 则 {
body = 转为JSON字符串(请求发送的数据)
}
else if 要发送的请求 是 GET请求 则 {
query = '&'
for k, v in 请求发送的数据 {
query += k + "=" + v + "&"
}
}
else {
body = 空
query = 空
}
if 是国服或渠道服 {
to_be_encrypted = "salt=" + salt + "&t=" + time + "&r=" + random + "&b=" + body + "&q=" + query
ds = 16位MD5加密(to_be_encrypted) // 小写
}
else if 是国际服 {
to_be_encrypted = "salt=" + salt + "&t=" + time + "&r=" + random
ds = 16位MD5加密(to_be_encrypted) // 小写
}
最终在请求头部的DS字段的内容 = timestamp + "," + random + "," + ds
Cookie
登录账号后服务器设置的Cookie值。
_MHYUUIDDEVICEFP_SEED_IDDEVICEFP_SEED_TIME_gacookie_token_v2account_mid_v2account_id_v2ltoken_v2ltmid_v2ltuid_v2DEVICEFP_ga_XXXXXXXX