mirror of
https://gitlab.com/Binaryify/neteasecloudmusicapi.git
synced 2025-05-23 22:37:41 +08:00
update: cookie 处理优化
This commit is contained in:
parent
2bb5269dfa
commit
7b6e9d90e0
@ -1,4 +1,10 @@
|
||||
# 更新日志
|
||||
### 4.17.0 | 2024.04.29
|
||||
- ua 更新
|
||||
- cookie 处理优化
|
||||
- 收藏与取消收藏歌单接口更新
|
||||
|
||||
|
||||
### 4.16.6 | 2024.04.25
|
||||
- ua 问题修复
|
||||
- 使用 crypto-js 重构 crypto 部分
|
||||
|
@ -1,6 +1,4 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
return request(
|
||||
'POST',
|
||||
`https://music.163.com/api/artist/head/info/get`,
|
||||
|
@ -1,6 +1,4 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
limit: query.limit || 20,
|
||||
startTimestamp: query.before || Date.now(),
|
||||
|
@ -1,6 +1,4 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
limit: query.limit || 20,
|
||||
startTimestamp: query.before || Date.now(),
|
||||
|
@ -1,5 +1,6 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
id: query.id,
|
||||
private_cloud: 'true',
|
||||
|
@ -10,8 +10,7 @@ module.exports = async (query, request) => {
|
||||
.replace('.' + ext, '')
|
||||
.replace(/\s/g, '')
|
||||
.replace(/\./g, '_')
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
|
||||
const bitrate = 999000
|
||||
if (!query.songFile) {
|
||||
return Promise.reject({
|
||||
|
@ -1,6 +1,4 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
userId: query.uid,
|
||||
songId: query.sid,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
// query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
rid: query.id,
|
||||
limit: query.limit || 20,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
rid: query.id,
|
||||
limit: query.limit || 20,
|
||||
|
@ -3,6 +3,7 @@ const { resourceTypeMap } = require('../util/config.json')
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.type = resourceTypeMap[query.type]
|
||||
const data = {
|
||||
rid: query.id,
|
||||
|
@ -1,7 +1,5 @@
|
||||
const { resourceTypeMap } = require('../util/config.json')
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
query.type = resourceTypeMap[query.type || 0]
|
||||
const threadId = query.type + query.sid
|
||||
const data = {
|
||||
|
@ -3,6 +3,7 @@ const { resourceTypeMap } = require('../util/config.json')
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.t = query.t == 1 ? 'like' : 'unlike'
|
||||
query.type = resourceTypeMap[query.type]
|
||||
const data = {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
rid: query.id,
|
||||
limit: query.limit || 20,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
rid: query.id,
|
||||
limit: query.limit || 20,
|
||||
|
@ -3,6 +3,7 @@ const { resourceTypeMap } = require('../util/config.json')
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.type = resourceTypeMap[query.type]
|
||||
const threadId = query.type + query.id
|
||||
const pageSize = query.pageSize || 20
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
rid: query.id,
|
||||
limit: query.limit || 20,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
rid: query.id,
|
||||
limit: query.limit || 20,
|
||||
|
@ -1,8 +1,8 @@
|
||||
// 电台banner
|
||||
|
||||
module.exports = (query, request) => {
|
||||
const data = {}
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
return request(
|
||||
'POST',
|
||||
`https://music.163.com/weapi/djradio/banner/get`,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
forwards: query.forwards,
|
||||
id: query.evId,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.t = query.t == 1 ? 'follow' : 'delfollow'
|
||||
return request(
|
||||
'POST',
|
||||
|
@ -2,8 +2,6 @@
|
||||
// 这个接口为移动端接口,首页-发现页,数据结构可以参考 https://github.com/hcanyz/flutter-netease-music-api/blob/master/lib/src/api/uncategorized/bean.dart#L259 HomeBlockPageWrap
|
||||
// query.refresh 是否刷新数据
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = { refresh: query.refresh || false, cursor: query.cursor }
|
||||
return request(
|
||||
'POST',
|
||||
|
@ -4,8 +4,7 @@
|
||||
// !需要登录或者游客登录,非登录返回 []
|
||||
module.exports = (query, request) => {
|
||||
const data = {}
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
|
||||
return request(
|
||||
'POST',
|
||||
`https://music.163.com/eapi/homepage/dragon/ball/static`,
|
||||
|
@ -1,7 +1,5 @@
|
||||
const { resourceTypeMap } = require('../util/config.json')
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
query.type = resourceTypeMap[query.type || 0]
|
||||
const threadId = query.type + query.sid
|
||||
const data = {
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 红心与取消红心歌曲
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
query.like = query.like == 'false' ? false : true
|
||||
const data = {
|
||||
alg: 'itembased',
|
||||
|
@ -3,8 +3,6 @@
|
||||
const CryptoJS = require('crypto-js')
|
||||
|
||||
module.exports = async (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
username: query.email,
|
||||
password: query.md5_password || CryptoJS.MD5(query.password).toString(),
|
||||
|
@ -3,8 +3,6 @@
|
||||
const CryptoJS = require('crypto-js')
|
||||
|
||||
module.exports = async (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
phone: query.phone,
|
||||
countrycode: query.countrycode || '86',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 登录刷新
|
||||
|
||||
module.exports = async (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
let result = await request(
|
||||
'POST',
|
||||
`https://music.163.com/weapi/login/token/refresh`,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
type: 'recommend',
|
||||
limit: query.limit || 10,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
name: query.name,
|
||||
privacy: query.privacy, //0 为普通歌单,10 为隐私歌单
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
ids: '[' + query.id + ']',
|
||||
}
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
ids: query.ids,
|
||||
}
|
||||
|
@ -7,7 +7,7 @@ module.exports = (query, request) => {
|
||||
}
|
||||
return request(
|
||||
'POST',
|
||||
`https://music.163.com/weapi/playlist/${query.t}`,
|
||||
`https://music.163.com/api/playlist/${query.t}`,
|
||||
data,
|
||||
{
|
||||
crypto: 'weapi',
|
||||
|
@ -8,7 +8,7 @@ module.exports = (query, request) => {
|
||||
}
|
||||
return request(
|
||||
'POST',
|
||||
`https://music.163.com/weapi/playlist/subscribers`,
|
||||
`https://music.163.com/api/playlist/subscribers`,
|
||||
data,
|
||||
{
|
||||
crypto: 'weapi',
|
||||
|
@ -1,5 +1,6 @@
|
||||
module.exports = async (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.ids = query.ids || ''
|
||||
const data = {
|
||||
id: query.pid,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = async (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.ids = query.ids || ''
|
||||
const data = {
|
||||
id: query.id,
|
||||
|
@ -1,7 +1,7 @@
|
||||
// 收藏单曲到歌单 从歌单删除歌曲
|
||||
|
||||
module.exports = async (query, request) => {
|
||||
// query.cookie.os = 'pc'
|
||||
//
|
||||
const tracks = query.tracks.split(',')
|
||||
const data = {
|
||||
op: query.op, // del,add
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
query.desc = query.desc || ''
|
||||
query.tags = query.tags || ''
|
||||
const data = {
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 更换手机
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
captcha: query.captcha,
|
||||
phone: query.phone,
|
||||
|
@ -3,6 +3,7 @@ const CryptoJS = require('crypto-js')
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
const data = {
|
||||
captcha: query.captcha,
|
||||
phone: query.phone,
|
||||
|
@ -16,6 +16,7 @@ module.exports = (query, request) => {
|
||||
realIP: query.realIP,
|
||||
})
|
||||
}
|
||||
query.cookie.os = 'pc'
|
||||
const data = {
|
||||
s: query.keywords,
|
||||
type: query.type || 1, // 1: 单曲, 10: 专辑, 100: 歌手, 1000: 歌单, 1002: 用户, 1004: MV, 1006: 歌词, 1009: 电台, 1014: 视频
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 私信专辑
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
id: query.id,
|
||||
msg: query.msg || '',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 私信歌单
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
id: query.playlist,
|
||||
type: 'playlist',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 私信歌曲
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
id: query.id,
|
||||
msg: query.msg || '',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 私信
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
type: 'text',
|
||||
msg: query.msg,
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 设置
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {}
|
||||
return request('POST', `https://music.163.com/api/user/setting`, data, {
|
||||
crypto: 'weapi',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 分享歌曲到动态
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
type: query.type || 'song', // song,playlist,mv,djprogram,djradio,noresource
|
||||
msg: query.msg || '',
|
||||
|
@ -1,7 +1,5 @@
|
||||
// 乐谱列表
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
id: query.id,
|
||||
abTest: query.ab || 'b',
|
||||
|
@ -1,6 +1,4 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {}
|
||||
return request('POST', `https://music.163.com/api/sign/happy/info`, data, {
|
||||
crypto: 'weapi',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 签到进度
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
moduleId: query.moduleId || '1207signin-1207signin',
|
||||
}
|
||||
|
@ -1,22 +1,26 @@
|
||||
// 歌曲链接
|
||||
module.exports = async (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
const ids = String(query.id).split(',')
|
||||
const data = {
|
||||
ids: JSON.stringify(ids),
|
||||
br: parseInt(query.br || 999000),
|
||||
trialMode: 2,
|
||||
immerseType: 'ste',
|
||||
ids: '["1328146041"]',
|
||||
os: 'iOS',
|
||||
level: 'exhigh',
|
||||
deviceId: 'a8c8c4d613b999dc5d13277b43c7e925',
|
||||
encodeType: 'aac',
|
||||
extPlay: 0,
|
||||
}
|
||||
const res = await request(
|
||||
'POST',
|
||||
`https://interface3.music.163.com/eapi/song/enhance/player/url`,
|
||||
`https://music.163.com/api/song/enhance/player/url/v1`,
|
||||
data,
|
||||
{
|
||||
crypto: 'eapi',
|
||||
crypto: 'weapi',
|
||||
cookie: query.cookie,
|
||||
ua: query.ua || '',
|
||||
proxy: query.proxy,
|
||||
realIP: query.realIP,
|
||||
url: '/api/song/enhance/player/url',
|
||||
},
|
||||
)
|
||||
// 根据id排序
|
||||
|
@ -3,8 +3,6 @@
|
||||
// 而是采用 standard, exhigh, lossless, hires, jyeffect(高清环绕声), sky(沉浸环绕声), jymaster(超清母带) 进行音质判断
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'android'
|
||||
query.cookie.appver = '8.10.05'
|
||||
const data = {
|
||||
ids: '[' + query.id + ']',
|
||||
level: query.level,
|
||||
|
@ -1,6 +1,7 @@
|
||||
// 排行榜
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'pc'
|
||||
query.cookie.appver = '2.9.7'
|
||||
if (query.idx) {
|
||||
return Promise.resolve({
|
||||
status: 500,
|
||||
|
@ -1,6 +1,4 @@
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
compose_reminder: 'true',
|
||||
compose_hot_comment: 'true',
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 用户动态
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
getcounts: true,
|
||||
time: query.lasttime || -1,
|
||||
|
@ -1,8 +1,6 @@
|
||||
// 编辑用户信息
|
||||
|
||||
module.exports = (query, request) => {
|
||||
query.cookie.os = 'ios'
|
||||
query.cookie.appver = '9.0.65'
|
||||
const data = {
|
||||
// avatarImgId: '0',
|
||||
birthday: query.birthday,
|
||||
|
@ -25,8 +25,7 @@ module.exports = async (query, request) => {
|
||||
.replace('.' + ext, '')
|
||||
.replace(/\s/g, '')
|
||||
.replace(/\./g, '_')
|
||||
// query.cookie.os = 'pc'
|
||||
// query.cookie.appver = '2.9.7'
|
||||
|
||||
if (!query.songFile) {
|
||||
return Promise.reject({
|
||||
status: 500,
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "NeteaseCloudMusicApi",
|
||||
"version": "4.16.6",
|
||||
"version": "4.17.0",
|
||||
"description": "网易云音乐 NodeJS 版 API",
|
||||
"scripts": {
|
||||
"start": "node app.js",
|
||||
|
@ -14,6 +14,14 @@ module.exports = {
|
||||
})
|
||||
return obj
|
||||
},
|
||||
cookieObjToString(cookie) {
|
||||
return Object.keys(cookie)
|
||||
.map(
|
||||
(key) =>
|
||||
`${encodeURIComponent(key)}=${encodeURIComponent(cookie[key])}`,
|
||||
)
|
||||
.join('; ')
|
||||
},
|
||||
getRandom(num) {
|
||||
var random = Math.floor(
|
||||
(Math.random() + Math.floor(Math.random() * 9 + 1)) *
|
||||
|
@ -8,18 +8,20 @@ const tunnel = require('tunnel')
|
||||
const fs = require('fs')
|
||||
const path = require('path')
|
||||
const tmpPath = require('os').tmpdir()
|
||||
const { cookieToJson, cookieObjToString } = require('./index')
|
||||
const anonymous_token = fs.readFileSync(
|
||||
path.resolve(tmpPath, './anonymous_token'),
|
||||
'utf-8',
|
||||
)
|
||||
const { URLSearchParams, URL } = require('url')
|
||||
const iosAppVersion = '9.0.65'
|
||||
// request.debug = true // 开启可看到更详细信息
|
||||
|
||||
const chooseUserAgent = (uaType) => {
|
||||
const userAgentMap = {
|
||||
mobile:
|
||||
'Mozilla/5.0 (iPhone; CPU iPhone OS 17_2_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/17.2 Mobile/15E148 Safari/604.1',
|
||||
pc: 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36 Edg/120.0.0.0',
|
||||
'Mozilla/5.0 (iPhone; CPU iPhone OS 17_4_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/17.4.1 Mobile/15E148 Safari/604.1',
|
||||
pc: 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36 Edg/124.0.0.0',
|
||||
}
|
||||
if (uaType === 'mobile') {
|
||||
return userAgentMap.mobile
|
||||
@ -27,9 +29,12 @@ const chooseUserAgent = (uaType) => {
|
||||
return userAgentMap.pc
|
||||
}
|
||||
const createRequest = (method, url, data = {}, options) => {
|
||||
const cookie = options.cookie || {}
|
||||
return new Promise((resolve, reject) => {
|
||||
let headers = {
|
||||
'User-Agent': options.ua || chooseUserAgent(options.uaType),
|
||||
os: cookie.os || 'ios',
|
||||
appver: cookie.appver || (cookie.os != 'pc' ? iosAppVersion : ''),
|
||||
}
|
||||
options.headers = options.headers || {}
|
||||
headers = {
|
||||
@ -53,6 +58,9 @@ const createRequest = (method, url, data = {}, options) => {
|
||||
__remember_me: true,
|
||||
// NMTID: CryptoJS.lib.WordArray.random(16).toString(),
|
||||
_ntes_nuid: CryptoJS.lib.WordArray.random(16).toString(),
|
||||
os: options.cookie.os || 'ios',
|
||||
appver:
|
||||
options.cookie.appver || (cookie.os != 'pc' ? iosAppVersion : ''),
|
||||
}
|
||||
if (url.indexOf('login') === -1) {
|
||||
options.cookie['NMTID'] = CryptoJS.lib.WordArray.random(16).toString()
|
||||
@ -61,22 +69,20 @@ const createRequest = (method, url, data = {}, options) => {
|
||||
// 游客
|
||||
if (!options.cookie.MUSIC_A) {
|
||||
options.cookie.MUSIC_A = anonymous_token
|
||||
options.cookie.os = options.cookie.os || 'ios'
|
||||
options.cookie.appver = options.cookie.appver || '9.0.65'
|
||||
}
|
||||
}
|
||||
headers['Cookie'] = Object.keys(options.cookie)
|
||||
.map(
|
||||
(key) =>
|
||||
encodeURIComponent(key) +
|
||||
'=' +
|
||||
encodeURIComponent(options.cookie[key]),
|
||||
)
|
||||
.join('; ')
|
||||
headers['Cookie'] = cookieObjToString(options.cookie)
|
||||
} else if (options.cookie) {
|
||||
headers['Cookie'] = options.cookie
|
||||
// cookie string
|
||||
const cookie = cookieToJson(options.cookie)
|
||||
cookie.os = cookie.os || 'ios'
|
||||
cookie.appver = cookie.appver || (cookie.os != 'pc' ? iosAppVersion : '')
|
||||
headers['Cookie'] = cookieObjToString(cookie)
|
||||
} else {
|
||||
headers['Cookie'] = '__remember_me=true; NMTID=xxx'
|
||||
const cookie = cookieToJson('__remember_me=true; NMTID=xxx')
|
||||
cookie.os = cookie.os || 'ios'
|
||||
cookie.appver = cookie.appver || (cookie.os != 'pc' ? iosAppVersion : '')
|
||||
headers['Cookie'] = cookieObjToString(cookie)
|
||||
}
|
||||
// console.log(options.cookie, headers['Cookie'])
|
||||
if (options.crypto === 'weapi') {
|
||||
@ -98,9 +104,9 @@ const createRequest = (method, url, data = {}, options) => {
|
||||
const cookie = options.cookie || {}
|
||||
const csrfToken = cookie['__csrf'] || ''
|
||||
const header = {
|
||||
osver: cookie.osver || '17.1.2', //系统版本
|
||||
deviceId: cookie.deviceId, //encrypt.base64.encode(imei + '\t02:00:00:00:00:00\t5106025eb79a5247\t70ffbaac7')
|
||||
appver: cookie.appver || '9.0.65', // app版本
|
||||
osver: cookie.osver || '17.4.1', //系统版本
|
||||
deviceId: cookie.deviceId || '', //encrypt.base64.encode(imei + '\t02:00:00:00:00:00\t5106025eb79a5247\t70ffbaac7')
|
||||
appver: cookie.appver || iosAppVersion, // app版本
|
||||
versioncode: cookie.versioncode || '140', //版本号
|
||||
mobilename: cookie.mobilename || '', //设备model
|
||||
buildver: cookie.buildver || Date.now().toString().substr(0, 10),
|
||||
@ -125,6 +131,7 @@ const createRequest = (method, url, data = {}, options) => {
|
||||
url = url.replace(/\w*api/, 'eapi')
|
||||
}
|
||||
const answer = { status: 500, body: {}, cookie: [] }
|
||||
// console.log(headers, 'headers')
|
||||
let settings = {
|
||||
method: method,
|
||||
url: url,
|
||||
|
Loading…
x
Reference in New Issue
Block a user