From 1eb178d0e4952443d2ca4f94dc594aa1c07f29dd Mon Sep 17 00:00:00 2001 From: binaryify Date: Sun, 21 Feb 2021 21:29:00 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=20eapi=20=E6=8E=A5=E5=8F=A3?= =?UTF-8?q?=E6=97=A0=E6=B3=95=E6=AD=A3=E7=A1=AE=E8=A7=A3=E5=AF=86response?= =?UTF-8?q?=E7=9A=84=E9=97=AE=E9=A2=98=20#1138?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- CHANGELOG.MD | 3 +++ package.json | 2 +- util/request.js | 17 ++++++++++++++--- 3 files changed, 18 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.MD b/CHANGELOG.MD index d01c9a22f17..e20246b9d6a 100644 --- a/CHANGELOG.MD +++ b/CHANGELOG.MD @@ -1,4 +1,7 @@ # 更新日志 +### 4.0.6 | 2021.2.20 +- 修复 eapi 接口无法正确解密response的问题 [#1138](https://github.com/Binaryify/NeteaseCloudMusicApi/issues/1138) + ### 4.0.5 | 2021.2.19 - 修复红心接口默认不红心的问题 [#1126](https://github.com/Binaryify/NeteaseCloudMusicApi/issues/1126) diff --git a/package.json b/package.json index 27e051828a5..87069b5dd9e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "NeteaseCloudMusicApi", - "version": "4.0.5", + "version": "4.0.6", "description": "网易云音乐 NodeJS 版 API", "scripts": { "start": "node app.js", diff --git a/util/request.js b/util/request.js index 0ad3b550c0b..b15d694b077 100644 --- a/util/request.js +++ b/util/request.js @@ -111,7 +111,7 @@ const createRequest = (method, url, data, options) => { } const answer = { status: 500, body: {}, cookie: [] } - const settings = { + let settings = { method: method, url: url, headers: headers, @@ -143,7 +143,12 @@ const createRequest = (method, url, data, options) => { } } } - + if (options.crypto === 'eapi') { + settings = { + ...settings, + responseType: 'arraybuffer', + } + } axios(settings) .then((res) => { const body = res.data @@ -151,7 +156,12 @@ const createRequest = (method, url, data, options) => { x.replace(/\s*Domain=[^(;|$)]+;*/, ''), ) try { - answer.body = body + if (options.crypto === 'eapi') { + answer.body = JSON.parse(encrypt.decrypt(body).toString()) + } else { + answer.body = body + } + answer.status = answer.body.code || res.status if ( [201, 302, 400, 502, 800, 801, 802, 803].indexOf(answer.body.code) > @@ -161,6 +171,7 @@ const createRequest = (method, url, data, options) => { answer.status = 200 } } catch (e) { + // console.log(e) answer.body = body answer.status = res.status }