Merge branch 'main' into 'main'

feat: eapi和api都生成cookie;甚至重新适配了linuxapi

See merge request Binaryify/neteasecloudmusicapi!14
This commit is contained in:
binaryify 2024-07-03 04:29:07 +00:00
commit b42e16f91e
3 changed files with 48 additions and 49 deletions

View File

@ -2,9 +2,10 @@ const createOption = require('../util/option.js')
module.exports = (query, request) => { module.exports = (query, request) => {
const method = query.method || 'POST' const method = query.method || 'POST'
const uri = query.uri const uri = query.uri
const data = query.data || {} const data =
typeof query.data === 'string' ? JSON.parse(query.data) : query.data || {}
const crypto = query.crypto || '' const crypto = query.crypto || ''
let res = request(method, uri, data, createOption(query, crypto)) const res = request(method, uri, data, createOption(query, crypto))
return res return res
} }

View File

@ -2,9 +2,7 @@
const createOption = require('../util/option.js') const createOption = require('../util/option.js')
module.exports = (query, request) => { module.exports = (query, request) => {
const data = { const data = {}
e_r: true,
}
Object.keys(query).forEach((i) => { Object.keys(query).forEach((i) => {
if (/^\/api\//.test(i)) { if (/^\/api\//.test(i)) {
data[i] = query[i] data[i] = query[i]

View File

@ -44,8 +44,6 @@ const createRequest = (method, uri, data = {}, options) => {
} }
if (method.toUpperCase() === 'POST') if (method.toUpperCase() === 'POST')
headers['Content-Type'] = 'application/x-www-form-urlencoded' headers['Content-Type'] = 'application/x-www-form-urlencoded'
if (uri.includes('music.163.com'))
headers['Referer'] = 'https://music.163.com'
let ip = options.realIP || options.ip || '' let ip = options.realIP || options.ip || ''
// console.log(ip) // console.log(ip)
if (ip) { if (ip) {
@ -86,9 +84,31 @@ const createRequest = (method, uri, data = {}, options) => {
headers['Cookie'] = cookieObjToString(cookie) headers['Cookie'] = cookieObjToString(cookie)
} }
// console.log(options.cookie, headers['Cookie']) // console.log(options.cookie, headers['Cookie'])
let url = '' let url = ''
let eapiEncrypt = () => { // 目前任意uri都支持三种加密方式
options['url'] = uri if (options.crypto === 'weapi') {
headers['Referer'] = 'https://music.163.com'
headers['User-Agent'] = options.ua || chooseUserAgent('pc')
let csrfToken = (headers['Cookie'] || '').match(/_csrf=([^(;|$)]+)/)
data.csrf_token = csrfToken ? csrfToken[1] : ''
data = encrypt.weapi(data)
url = APP_CONF.domain + '/weapi/' + uri.substr(5)
} else if (options.crypto === 'linuxapi') {
headers['User-Agent'] =
'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.90 Safari/537.36'
data = encrypt.linuxapi({
method: method,
url: APP_CONF.apiDomain + uri,
params: data,
})
url = 'https://music.163.com/api/linux/forward'
} else if (
options.crypto === 'eapi' ||
options.crypto === 'api' ||
options.crypto === ''
) {
// 两种加密方式都应生成客户端的cookie
const cookie = options.cookie || {} const cookie = options.cookie || {}
const csrfToken = cookie['__csrf'] || '' const csrfToken = cookie['__csrf'] || ''
const header = { const header = {
@ -114,34 +134,26 @@ const createRequest = (method, uri, data = {}, options) => {
encodeURIComponent(key) + '=' + encodeURIComponent(header[key]), encodeURIComponent(key) + '=' + encodeURIComponent(header[key]),
) )
.join('; ') .join('; ')
let eapiEncrypt = () => {
data.header = header data.header = header
data = encrypt.eapi(options.url, data) data = encrypt.eapi(uri, data)
url = APP_CONF.apiDomain + '/eapi/' + uri.substr(5) url = APP_CONF.apiDomain + '/eapi/' + uri.substr(5)
} }
if (options.crypto === 'weapi') { if (options.crypto === 'eapi') {
headers['User-Agent'] = options.ua || chooseUserAgent('pc')
let csrfToken = (headers['Cookie'] || '').match(/_csrf=([^(;|$)]+)/)
data.csrf_token = csrfToken ? csrfToken[1] : ''
data = encrypt.weapi(data)
url = APP_CONF.domain + '/weapi/' + uri.substr(5)
} else if (options.crypto === 'linuxapi') {
data = encrypt.linuxapi({
method: method,
url: uri.replace(/\w*api/, 'api'),
params: data,
})
headers['User-Agent'] =
'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.90 Safari/537.36'
url = 'https://music.163.com/api/linux/forward'
} else if (options.crypto === 'eapi') {
eapiEncrypt() eapiEncrypt()
} else if (options.crypto === 'api') { } else if (options.crypto === 'api') {
url = APP_CONF.apiDomain + uri url = APP_CONF.apiDomain + uri
} else if (options.crypto === '') { } else if (options.crypto === '') {
// 加密方式为空,以配置文件的加密方式为准
if (APP_CONF.encrypt) { if (APP_CONF.encrypt) {
eapiEncrypt() eapiEncrypt()
} else url = APP_CONF.apiDomain + uri } else url = APP_CONF.apiDomain + uri
} }
} else {
// 未知的加密方式
console.log('[ERR]', 'Unknown Crypto:', options.crypto)
}
const answer = { status: 500, body: {}, cookie: [] } const answer = { status: 500, body: {}, cookie: [] }
// console.log(headers, 'headers') // console.log(headers, 'headers')
let settings = { let settings = {
@ -153,8 +165,6 @@ const createRequest = (method, uri, data = {}, options) => {
httpsAgent: new https.Agent({ keepAlive: true }), httpsAgent: new https.Agent({ keepAlive: true }),
} }
if (options.crypto === 'eapi') settings.encoding = null
if (options.proxy) { if (options.proxy) {
if (options.proxy.indexOf('pac') > -1) { if (options.proxy.indexOf('pac') > -1) {
settings.httpAgent = new PacProxyAgent(options.proxy) settings.httpAgent = new PacProxyAgent(options.proxy)
@ -184,12 +194,6 @@ const createRequest = (method, uri, data = {}, options) => {
} else { } else {
settings.proxy = false settings.proxy = false
} }
if (options.crypto === 'eapi') {
settings = {
...settings,
responseType: 'arraybuffer',
}
}
axios(settings) axios(settings)
.then((res) => { .then((res) => {
const body = res.data const body = res.data
@ -197,11 +201,7 @@ const createRequest = (method, uri, data = {}, options) => {
x.replace(/\s*Domain=[^(;|$)]+;*/, ''), x.replace(/\s*Domain=[^(;|$)]+;*/, ''),
) )
try { try {
if (options.crypto === 'eapi') { answer.body = JSON.parse(body.toString())
answer.body = JSON.parse(encrypt.decrypt(body))
} else {
answer.body = body
}
if (answer.body.code) { if (answer.body.code) {
answer.body.code = Number(answer.body.code) answer.body.code = Number(answer.body.code)
} }
@ -217,7 +217,7 @@ const createRequest = (method, uri, data = {}, options) => {
} catch (e) { } catch (e) {
// console.log(e) // console.log(e)
try { try {
answer.body = JSON.parse(body.toString()) answer.body = JSON.parse(encrypt.decrypt(body))
} catch (err) { } catch (err) {
// console.log(err) // console.log(err)
// can't decrypt and can't parse directly // can't decrypt and can't parse directly