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
|
### 4.16.6 | 2024.04.25
|
||||||
- ua 问题修复
|
- ua 问题修复
|
||||||
- 使用 crypto-js 重构 crypto 部分
|
- 使用 crypto-js 重构 crypto 部分
|
||||||
|
@ -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`,
|
||||||
|
@ -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(),
|
||||||
|
@ -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(),
|
||||||
|
@ -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',
|
||||||
|
@ -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({
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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 = {
|
||||||
|
@ -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 = {
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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`,
|
||||||
|
@ -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,
|
||||||
|
@ -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',
|
||||||
|
@ -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',
|
||||||
|
@ -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`,
|
||||||
|
@ -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 = {
|
||||||
|
@ -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',
|
||||||
|
@ -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(),
|
||||||
|
@ -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',
|
||||||
|
@ -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`,
|
||||||
|
@ -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,
|
||||||
|
@ -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 为隐私歌单
|
||||||
|
@ -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 + ']',
|
||||||
}
|
}
|
||||||
|
@ -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,
|
||||||
}
|
}
|
||||||
|
@ -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',
|
||||||
|
@ -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',
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
|
@ -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 = {
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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: 视频
|
||||||
|
@ -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 || '',
|
||||||
|
@ -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',
|
||||||
|
@ -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 || '',
|
||||||
|
@ -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,
|
||||||
|
@ -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',
|
||||||
|
@ -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 || '',
|
||||||
|
@ -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',
|
||||||
|
@ -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',
|
||||||
|
@ -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',
|
||||||
}
|
}
|
||||||
|
@ -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排序
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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',
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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",
|
||||||
|
@ -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)) *
|
||||||
|
@ -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,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user