update: cookie 处理优化

This commit is contained in:
binaryify 2024-04-29 15:23:41 +08:00
parent 2bb5269dfa
commit 7b6e9d90e0
59 changed files with 78 additions and 84 deletions

View File

@ -1,4 +1,10 @@
# 更新日志 # 更新日志
### 4.17.0 | 2024.04.29
- ua 更新
- cookie 处理优化
- 收藏与取消收藏歌单接口更新
### 4.16.6 | 2024.04.25 ### 4.16.6 | 2024.04.25
- ua 问题修复 - ua 问题修复
- 使用 crypto-js 重构 crypto 部分 - 使用 crypto-js 重构 crypto 部分

View File

@ -1,6 +1,4 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
return request( return request(
'POST', 'POST',
`https://music.163.com/api/artist/head/info/get`, `https://music.163.com/api/artist/head/info/get`,

View File

@ -1,6 +1,4 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
limit: query.limit || 20, limit: query.limit || 20,
startTimestamp: query.before || Date.now(), startTimestamp: query.before || Date.now(),

View File

@ -1,6 +1,4 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
limit: query.limit || 20, limit: query.limit || 20,
startTimestamp: query.before || Date.now(), startTimestamp: query.before || Date.now(),

View File

@ -1,5 +1,6 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
id: query.id, id: query.id,
private_cloud: 'true', private_cloud: 'true',

View File

@ -10,8 +10,7 @@ module.exports = async (query, request) => {
.replace('.' + ext, '') .replace('.' + ext, '')
.replace(/\s/g, '') .replace(/\s/g, '')
.replace(/\./g, '_') .replace(/\./g, '_')
query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const bitrate = 999000 const bitrate = 999000
if (!query.songFile) { if (!query.songFile) {
return Promise.reject({ return Promise.reject({

View File

@ -1,6 +1,4 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
userId: query.uid, userId: query.uid,
songId: query.sid, songId: query.sid,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
// query.cookie.appver = '2.9.7'
const data = { const data = {
rid: query.id, rid: query.id,
limit: query.limit || 20, limit: query.limit || 20,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
rid: query.id, rid: query.id,
limit: query.limit || 20, limit: query.limit || 20,

View File

@ -3,6 +3,7 @@ const { resourceTypeMap } = require('../util/config.json')
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.type = resourceTypeMap[query.type] query.type = resourceTypeMap[query.type]
const data = { const data = {
rid: query.id, rid: query.id,

View File

@ -1,7 +1,5 @@
const { resourceTypeMap } = require('../util/config.json') const { resourceTypeMap } = require('../util/config.json')
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
query.type = resourceTypeMap[query.type || 0] query.type = resourceTypeMap[query.type || 0]
const threadId = query.type + query.sid const threadId = query.type + query.sid
const data = { const data = {

View File

@ -3,6 +3,7 @@ const { resourceTypeMap } = require('../util/config.json')
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.t = query.t == 1 ? 'like' : 'unlike' query.t = query.t == 1 ? 'like' : 'unlike'
query.type = resourceTypeMap[query.type] query.type = resourceTypeMap[query.type]
const data = { const data = {

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
rid: query.id, rid: query.id,
limit: query.limit || 20, limit: query.limit || 20,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
rid: query.id, rid: query.id,
limit: query.limit || 20, limit: query.limit || 20,

View File

@ -3,6 +3,7 @@ const { resourceTypeMap } = require('../util/config.json')
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.type = resourceTypeMap[query.type] query.type = resourceTypeMap[query.type]
const threadId = query.type + query.id const threadId = query.type + query.id
const pageSize = query.pageSize || 20 const pageSize = query.pageSize || 20

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
rid: query.id, rid: query.id,
limit: query.limit || 20, limit: query.limit || 20,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
rid: query.id, rid: query.id,
limit: query.limit || 20, limit: query.limit || 20,

View File

@ -1,8 +1,8 @@
// 电台banner // 电台banner
module.exports = (query, request) => { module.exports = (query, request) => {
const data = {}
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
return request( return request(
'POST', 'POST',
`https://music.163.com/weapi/djradio/banner/get`, `https://music.163.com/weapi/djradio/banner/get`,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
forwards: query.forwards, forwards: query.forwards,
id: query.evId, id: query.evId,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.t = query.t == 1 ? 'follow' : 'delfollow' query.t = query.t == 1 ? 'follow' : 'delfollow'
return request( return request(
'POST', 'POST',

View File

@ -2,8 +2,6 @@
// 这个接口为移动端接口,首页-发现页,数据结构可以参考 https://github.com/hcanyz/flutter-netease-music-api/blob/master/lib/src/api/uncategorized/bean.dart#L259 HomeBlockPageWrap // 这个接口为移动端接口,首页-发现页,数据结构可以参考 https://github.com/hcanyz/flutter-netease-music-api/blob/master/lib/src/api/uncategorized/bean.dart#L259 HomeBlockPageWrap
// query.refresh 是否刷新数据 // query.refresh 是否刷新数据
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { refresh: query.refresh || false, cursor: query.cursor } const data = { refresh: query.refresh || false, cursor: query.cursor }
return request( return request(
'POST', 'POST',

View File

@ -4,8 +4,7 @@
// !需要登录或者游客登录,非登录返回 [] // !需要登录或者游客登录,非登录返回 []
module.exports = (query, request) => { module.exports = (query, request) => {
const data = {} const data = {}
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
return request( return request(
'POST', 'POST',
`https://music.163.com/eapi/homepage/dragon/ball/static`, `https://music.163.com/eapi/homepage/dragon/ball/static`,

View File

@ -1,7 +1,5 @@
const { resourceTypeMap } = require('../util/config.json') const { resourceTypeMap } = require('../util/config.json')
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
query.type = resourceTypeMap[query.type || 0] query.type = resourceTypeMap[query.type || 0]
const threadId = query.type + query.sid const threadId = query.type + query.sid
const data = { const data = {

View File

@ -1,8 +1,6 @@
// 红心与取消红心歌曲 // 红心与取消红心歌曲
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
query.like = query.like == 'false' ? false : true query.like = query.like == 'false' ? false : true
const data = { const data = {
alg: 'itembased', alg: 'itembased',

View File

@ -3,8 +3,6 @@
const CryptoJS = require('crypto-js') const CryptoJS = require('crypto-js')
module.exports = async (query, request) => { module.exports = async (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
username: query.email, username: query.email,
password: query.md5_password || CryptoJS.MD5(query.password).toString(), password: query.md5_password || CryptoJS.MD5(query.password).toString(),

View File

@ -3,8 +3,6 @@
const CryptoJS = require('crypto-js') const CryptoJS = require('crypto-js')
module.exports = async (query, request) => { module.exports = async (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
phone: query.phone, phone: query.phone,
countrycode: query.countrycode || '86', countrycode: query.countrycode || '86',

View File

@ -1,8 +1,6 @@
// 登录刷新 // 登录刷新
module.exports = async (query, request) => { module.exports = async (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
let result = await request( let result = await request(
'POST', 'POST',
`https://music.163.com/weapi/login/token/refresh`, `https://music.163.com/weapi/login/token/refresh`,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
type: 'recommend', type: 'recommend',
limit: query.limit || 10, limit: query.limit || 10,

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
name: query.name, name: query.name,
privacy: query.privacy, //0 为普通歌单10 为隐私歌单 privacy: query.privacy, //0 为普通歌单10 为隐私歌单

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
ids: '[' + query.id + ']', ids: '[' + query.id + ']',
} }

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
ids: query.ids, ids: query.ids,
} }

View File

@ -7,7 +7,7 @@ module.exports = (query, request) => {
} }
return request( return request(
'POST', 'POST',
`https://music.163.com/weapi/playlist/${query.t}`, `https://music.163.com/api/playlist/${query.t}`,
data, data,
{ {
crypto: 'weapi', crypto: 'weapi',

View File

@ -8,7 +8,7 @@ module.exports = (query, request) => {
} }
return request( return request(
'POST', 'POST',
`https://music.163.com/weapi/playlist/subscribers`, `https://music.163.com/api/playlist/subscribers`,
data, data,
{ {
crypto: 'weapi', crypto: 'weapi',

View File

@ -1,5 +1,6 @@
module.exports = async (query, request) => { module.exports = async (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.ids = query.ids || '' query.ids = query.ids || ''
const data = { const data = {
id: query.pid, id: query.pid,

View File

@ -2,6 +2,7 @@
module.exports = async (query, request) => { module.exports = async (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.ids = query.ids || '' query.ids = query.ids || ''
const data = { const data = {
id: query.id, id: query.id,

View File

@ -1,7 +1,7 @@
// 收藏单曲到歌单 从歌单删除歌曲 // 收藏单曲到歌单 从歌单删除歌曲
module.exports = async (query, request) => { module.exports = async (query, request) => {
// query.cookie.os = 'pc' //
const tracks = query.tracks.split(',') const tracks = query.tracks.split(',')
const data = { const data = {
op: query.op, // del,add op: query.op, // del,add

View File

@ -2,6 +2,7 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
query.desc = query.desc || '' query.desc = query.desc || ''
query.tags = query.tags || '' query.tags = query.tags || ''
const data = { const data = {

View File

@ -1,8 +1,6 @@
// 更换手机 // 更换手机
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
captcha: query.captcha, captcha: query.captcha,
phone: query.phone, phone: query.phone,

View File

@ -3,6 +3,7 @@ const CryptoJS = require('crypto-js')
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
const data = { const data = {
captcha: query.captcha, captcha: query.captcha,
phone: query.phone, phone: query.phone,

View File

@ -16,6 +16,7 @@ module.exports = (query, request) => {
realIP: query.realIP, realIP: query.realIP,
}) })
} }
query.cookie.os = 'pc'
const data = { const data = {
s: query.keywords, s: query.keywords,
type: query.type || 1, // 1: 单曲, 10: 专辑, 100: 歌手, 1000: 歌单, 1002: 用户, 1004: MV, 1006: 歌词, 1009: 电台, 1014: 视频 type: query.type || 1, // 1: 单曲, 10: 专辑, 100: 歌手, 1000: 歌单, 1002: 用户, 1004: MV, 1006: 歌词, 1009: 电台, 1014: 视频

View File

@ -1,8 +1,6 @@
// 私信专辑 // 私信专辑
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
id: query.id, id: query.id,
msg: query.msg || '', msg: query.msg || '',

View File

@ -1,8 +1,6 @@
// 私信歌单 // 私信歌单
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
id: query.playlist, id: query.playlist,
type: 'playlist', type: 'playlist',

View File

@ -1,8 +1,6 @@
// 私信歌曲 // 私信歌曲
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
id: query.id, id: query.id,
msg: query.msg || '', msg: query.msg || '',

View File

@ -1,8 +1,6 @@
// 私信 // 私信
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
type: 'text', type: 'text',
msg: query.msg, msg: query.msg,

View File

@ -1,8 +1,6 @@
// 设置 // 设置
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = {} const data = {}
return request('POST', `https://music.163.com/api/user/setting`, data, { return request('POST', `https://music.163.com/api/user/setting`, data, {
crypto: 'weapi', crypto: 'weapi',

View File

@ -1,8 +1,6 @@
// 分享歌曲到动态 // 分享歌曲到动态
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
type: query.type || 'song', // song,playlist,mv,djprogram,djradio,noresource type: query.type || 'song', // song,playlist,mv,djprogram,djradio,noresource
msg: query.msg || '', msg: query.msg || '',

View File

@ -1,7 +1,5 @@
// 乐谱列表 // 乐谱列表
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
id: query.id, id: query.id,
abTest: query.ab || 'b', abTest: query.ab || 'b',

View File

@ -1,6 +1,4 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = {} const data = {}
return request('POST', `https://music.163.com/api/sign/happy/info`, data, { return request('POST', `https://music.163.com/api/sign/happy/info`, data, {
crypto: 'weapi', crypto: 'weapi',

View File

@ -1,8 +1,6 @@
// 签到进度 // 签到进度
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
moduleId: query.moduleId || '1207signin-1207signin', moduleId: query.moduleId || '1207signin-1207signin',
} }

View File

@ -1,22 +1,26 @@
// 歌曲链接 // 歌曲链接
module.exports = async (query, request) => { module.exports = async (query, request) => {
query.cookie.os = 'pc'
const ids = String(query.id).split(',') const ids = String(query.id).split(',')
const data = { const data = {
ids: JSON.stringify(ids), trialMode: 2,
br: parseInt(query.br || 999000), immerseType: 'ste',
ids: '["1328146041"]',
os: 'iOS',
level: 'exhigh',
deviceId: 'a8c8c4d613b999dc5d13277b43c7e925',
encodeType: 'aac',
extPlay: 0,
} }
const res = await request( const res = await request(
'POST', 'POST',
`https://interface3.music.163.com/eapi/song/enhance/player/url`, `https://music.163.com/api/song/enhance/player/url/v1`,
data, data,
{ {
crypto: 'eapi', crypto: 'weapi',
cookie: query.cookie, cookie: query.cookie,
ua: query.ua || '', ua: query.ua || '',
proxy: query.proxy, proxy: query.proxy,
realIP: query.realIP, realIP: query.realIP,
url: '/api/song/enhance/player/url',
}, },
) )
// 根据id排序 // 根据id排序

View File

@ -3,8 +3,6 @@
// 而是采用 standard, exhigh, lossless, hires, jyeffect(高清环绕声), sky(沉浸环绕声), jymaster(超清母带) 进行音质判断 // 而是采用 standard, exhigh, lossless, hires, jyeffect(高清环绕声), sky(沉浸环绕声), jymaster(超清母带) 进行音质判断
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'android'
query.cookie.appver = '8.10.05'
const data = { const data = {
ids: '[' + query.id + ']', ids: '[' + query.id + ']',
level: query.level, level: query.level,

View File

@ -1,6 +1,7 @@
// 排行榜 // 排行榜
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'pc' query.cookie.os = 'pc'
query.cookie.appver = '2.9.7'
if (query.idx) { if (query.idx) {
return Promise.resolve({ return Promise.resolve({
status: 500, status: 500,

View File

@ -1,6 +1,4 @@
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
compose_reminder: 'true', compose_reminder: 'true',
compose_hot_comment: 'true', compose_hot_comment: 'true',

View File

@ -1,8 +1,6 @@
// 用户动态 // 用户动态
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
getcounts: true, getcounts: true,
time: query.lasttime || -1, time: query.lasttime || -1,

View File

@ -1,8 +1,6 @@
// 编辑用户信息 // 编辑用户信息
module.exports = (query, request) => { module.exports = (query, request) => {
query.cookie.os = 'ios'
query.cookie.appver = '9.0.65'
const data = { const data = {
// avatarImgId: '0', // avatarImgId: '0',
birthday: query.birthday, birthday: query.birthday,

View File

@ -25,8 +25,7 @@ module.exports = async (query, request) => {
.replace('.' + ext, '') .replace('.' + ext, '')
.replace(/\s/g, '') .replace(/\s/g, '')
.replace(/\./g, '_') .replace(/\./g, '_')
// query.cookie.os = 'pc'
// query.cookie.appver = '2.9.7'
if (!query.songFile) { if (!query.songFile) {
return Promise.reject({ return Promise.reject({
status: 500, status: 500,

View File

@ -1,6 +1,6 @@
{ {
"name": "NeteaseCloudMusicApi", "name": "NeteaseCloudMusicApi",
"version": "4.16.6", "version": "4.17.0",
"description": "网易云音乐 NodeJS 版 API", "description": "网易云音乐 NodeJS 版 API",
"scripts": { "scripts": {
"start": "node app.js", "start": "node app.js",

View File

@ -14,6 +14,14 @@ module.exports = {
}) })
return obj return obj
}, },
cookieObjToString(cookie) {
return Object.keys(cookie)
.map(
(key) =>
`${encodeURIComponent(key)}=${encodeURIComponent(cookie[key])}`,
)
.join('; ')
},
getRandom(num) { getRandom(num) {
var random = Math.floor( var random = Math.floor(
(Math.random() + Math.floor(Math.random() * 9 + 1)) * (Math.random() + Math.floor(Math.random() * 9 + 1)) *

View File

@ -8,18 +8,20 @@ const tunnel = require('tunnel')
const fs = require('fs') const fs = require('fs')
const path = require('path') const path = require('path')
const tmpPath = require('os').tmpdir() const tmpPath = require('os').tmpdir()
const { cookieToJson, cookieObjToString } = require('./index')
const anonymous_token = fs.readFileSync( const anonymous_token = fs.readFileSync(
path.resolve(tmpPath, './anonymous_token'), path.resolve(tmpPath, './anonymous_token'),
'utf-8', 'utf-8',
) )
const { URLSearchParams, URL } = require('url') const { URLSearchParams, URL } = require('url')
const iosAppVersion = '9.0.65'
// request.debug = true // 开启可看到更详细信息 // request.debug = true // 开启可看到更详细信息
const chooseUserAgent = (uaType) => { const chooseUserAgent = (uaType) => {
const userAgentMap = { const userAgentMap = {
mobile: 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', '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 (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', 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') { if (uaType === 'mobile') {
return userAgentMap.mobile return userAgentMap.mobile
@ -27,9 +29,12 @@ const chooseUserAgent = (uaType) => {
return userAgentMap.pc return userAgentMap.pc
} }
const createRequest = (method, url, data = {}, options) => { const createRequest = (method, url, data = {}, options) => {
const cookie = options.cookie || {}
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
let headers = { let headers = {
'User-Agent': options.ua || chooseUserAgent(options.uaType), 'User-Agent': options.ua || chooseUserAgent(options.uaType),
os: cookie.os || 'ios',
appver: cookie.appver || (cookie.os != 'pc' ? iosAppVersion : ''),
} }
options.headers = options.headers || {} options.headers = options.headers || {}
headers = { headers = {
@ -53,6 +58,9 @@ const createRequest = (method, url, data = {}, options) => {
__remember_me: true, __remember_me: true,
// NMTID: CryptoJS.lib.WordArray.random(16).toString(), // NMTID: CryptoJS.lib.WordArray.random(16).toString(),
_ntes_nuid: 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) { if (url.indexOf('login') === -1) {
options.cookie['NMTID'] = CryptoJS.lib.WordArray.random(16).toString() options.cookie['NMTID'] = CryptoJS.lib.WordArray.random(16).toString()
@ -61,22 +69,20 @@ const createRequest = (method, url, data = {}, options) => {
// 游客 // 游客
if (!options.cookie.MUSIC_A) { if (!options.cookie.MUSIC_A) {
options.cookie.MUSIC_A = anonymous_token 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) headers['Cookie'] = cookieObjToString(options.cookie)
.map(
(key) =>
encodeURIComponent(key) +
'=' +
encodeURIComponent(options.cookie[key]),
)
.join('; ')
} else if (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 { } 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']) // console.log(options.cookie, headers['Cookie'])
if (options.crypto === 'weapi') { if (options.crypto === 'weapi') {
@ -98,9 +104,9 @@ const createRequest = (method, url, data = {}, options) => {
const cookie = options.cookie || {} const cookie = options.cookie || {}
const csrfToken = cookie['__csrf'] || '' const csrfToken = cookie['__csrf'] || ''
const header = { const header = {
osver: cookie.osver || '17.1.2', //系统版本 osver: cookie.osver || '17.4.1', //系统版本
deviceId: cookie.deviceId, //encrypt.base64.encode(imei + '\t02:00:00:00:00:00\t5106025eb79a5247\t70ffbaac7') deviceId: cookie.deviceId || '', //encrypt.base64.encode(imei + '\t02:00:00:00:00:00\t5106025eb79a5247\t70ffbaac7')
appver: cookie.appver || '9.0.65', // app版本 appver: cookie.appver || iosAppVersion, // app版本
versioncode: cookie.versioncode || '140', //版本号 versioncode: cookie.versioncode || '140', //版本号
mobilename: cookie.mobilename || '', //设备model mobilename: cookie.mobilename || '', //设备model
buildver: cookie.buildver || Date.now().toString().substr(0, 10), 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') url = url.replace(/\w*api/, 'eapi')
} }
const answer = { status: 500, body: {}, cookie: [] } const answer = { status: 500, body: {}, cookie: [] }
// console.log(headers, 'headers')
let settings = { let settings = {
method: method, method: method,
url: url, url: url,