2
0
mirror of https://github.com/ctrlcvs/xiaoyao-cvs-plugin.git synced 2024-12-23 11:40:51 +08:00

修正获取stoken方法 兼容V2 V3最新版本

This commit is contained in:
Ctrlcvs 2022-07-29 15:02:43 +08:00 committed by leiyilu
parent 454b18d780
commit 3bafc24416

View File

@ -4,7 +4,9 @@ import _ from 'lodash';
import superagent from 'superagent'; import superagent from 'superagent';
import fs from "fs"; import fs from "fs";
import YAML from 'yaml' import YAML from 'yaml'
import {Data} from "../../components/index.js"; import {
Data
} from "../../components/index.js";
import fetch from "node-fetch" import fetch from "node-fetch"
const APP_VERSION = "2.2.0"; const APP_VERSION = "2.2.0";
const DEVICE_ID = utils.randomString(32).toUpperCase(); const DEVICE_ID = utils.randomString(32).toUpperCase();
@ -67,13 +69,13 @@ export default class MihoYoApi {
return resObj; return resObj;
} }
async stoken(cookie, e) { async stoken(cookie, e) {
this.e=e; this.e = e;
if(Object.keys(this.getStoken(e.user_id)).length != 0){ if (Object.keys(this.getStoken(e.user_id)).length != 0) {
return true; return true;
} }
const map = this.getCookieMap(cookie); const map = this.getCookieMap(cookie);
const loginTicket = map.get("login_ticket"); const loginTicket = map.get("login_ticket");
const loginUid = map.get("login_uid"); const loginUid = map.get("login_uid") ? map.get("login_uid") : map.get("ltuid");
const url = "https://api-takumi.mihoyo.com/auth/api/getMultiTokenByLoginTicket?login_ticket=" + const url = "https://api-takumi.mihoyo.com/auth/api/getMultiTokenByLoginTicket?login_ticket=" +
loginTicket + "&token_types=3&uid=" + loginUid; loginTicket + "&token_types=3&uid=" + loginUid;
fetch(url, { fetch(url, {
@ -96,7 +98,7 @@ export default class MihoYoApi {
} }
response.json().then(function(data) { response.json().then(function(data) {
// console.log(data); // console.log(data);
if(!data.data){ if (!data.data) {
return false; return false;
} }
let datalist = { let datalist = {
@ -118,11 +120,11 @@ export default class MihoYoApi {
_getHeader() { _getHeader() {
const randomStr = utils.randomString(6); const randomStr = utils.randomString(6);
const timestamp = Math.floor(Date.now() / 1000) const timestamp = Math.floor(Date.now() / 1000)
let data=this.getStoken(this.e.user_id); let data = this.getStoken(this.e.user_id);
// console.log(data) // console.log(data)
// iOS sign // iOS sign
let sign = md5(`salt=b253c83ab2609b1b600eddfe974df47b&t=${timestamp}&r=${randomStr}`); let sign = md5(`salt=b253c83ab2609b1b600eddfe974df47b&t=${timestamp}&r=${randomStr}`);
let cookie =`stuid=${data.stuid};stoken=${data.stoken};ltoken=${data.ltoken};`; let cookie = `stuid=${data.stuid};stoken=${data.stoken};ltoken=${data.ltoken};`;
return { return {
'Cookie': cookie, 'Cookie': cookie,
'Content-Type': 'application/json', 'Content-Type': 'application/json',
@ -140,11 +142,12 @@ export default class MihoYoApi {
} }
getCookieMap(cookie) { getCookieMap(cookie) {
let cookiePattern = /^(\S+)=(\S+)$/; let cookiePattern = /^(\S+)=(\S+)$/;
let cookieArray = cookie.split("; "); let cookieArray = cookie.replace(/\s*/g,"").split(";");
let cookieMap = new Map(); let cookieMap = new Map();
for (let item of cookieArray) { for (let item of cookieArray) {
let entry = cookiePattern.exec(item); let entry = item.split("=");
cookieMap.set(entry[1], entry[2]); if(!entry[0]) continue;
cookieMap.set(entry[0], entry[1]);
} }
return cookieMap; return cookieMap;
} }