From e891287f1a99c948321494fa8de0542ef8bb50c4 Mon Sep 17 00:00:00 2001 From: imsyy Date: Sat, 28 Feb 2026 14:42:25 +0800 Subject: [PATCH 1/3] =?UTF-8?q?feat:=20=E6=B7=BB=E5=8A=A0=E8=AF=84?= =?UTF-8?q?=E8=AE=BA=E7=BB=9F=E8=AE=A1=E6=95=B0=E6=8D=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- module/comment_info_list.js | 30 ++++++++++++++++++++++++++++++ public/docs/home.md | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 module/comment_info_list.js diff --git a/module/comment_info_list.js b/module/comment_info_list.js new file mode 100644 index 0000000..2c25d99 --- /dev/null +++ b/module/comment_info_list.js @@ -0,0 +1,30 @@ +// 评论统计数据 +// type: 0=歌曲 1=MV 2=歌单 3=专辑 4=电台节目 5=视频 6=动态 7=电台 +// ids: 资源 ID 列表,多个用逗号分隔,如 "123,456" +const { resourceTypeMap } = require('../util/config.json') +const createOption = require('../util/option.js') + +// 从 resourceTypeMap 的前缀值中提取网易云内部资源类型编号 +// 例如 "R_SO_4_" -> "4", "A_DR_14_" -> "14" +const resourceTypeIdMap = Object.fromEntries( + Object.entries(resourceTypeMap).map(([key, prefix]) => [ + key, + prefix.replace(/_$/, '').split('_').pop(), + ]), +) + +module.exports = (query, request) => { + const ids = String(query.ids || query.id || '') + .split(',') + .map((id) => id.trim()) + .filter(Boolean) + + return request( + `/api/resource/commentInfo/list`, + { + resourceType: resourceTypeIdMap[String(query.type || 0)], + resourceIds: JSON.stringify(ids), + }, + createOption(query, 'weapi'), + ) +} diff --git a/public/docs/home.md b/public/docs/home.md index f3ce57f..b552ddf 100644 --- a/public/docs/home.md +++ b/public/docs/home.md @@ -1686,6 +1686,38 @@ tags: 歌单标签 **调用例子 :** `/comment/video?id=89ADDE33C0AAE8EC14B99F6750DB954D` +### 评论统计数据 + +说明 : 调用此接口 , 传入资源类型和资源 id 列表 , 可批量获取对应资源的评论统计数据 ( 不需要登录 ) + +**必选参数 :** + +`type`: 数字 , 资源类型 , 对应以下类型 + +``` +0: 歌曲 + +1: mv + +2: 歌单 + +3: 专辑 + +4: 电台节目 + +5: 视频 + +6: 动态 + +7: 电台 +``` + +`ids`: 资源 id 列表 , 多个 id 用逗号分隔 , 如 `123,456` + +**接口地址 :** `/comment/info/list` + +**调用例子 :** `/comment/info/list?type=0&ids=186016,347230` + ### 热门评论 说明 : 调用此接口 , 传入 type, 资源 id 可获得对应资源热门评论 ( 不需要登录 ) From bde1f0864babe0e5042921595a9a3893581bd077 Mon Sep 17 00:00:00 2001 From: imsyy Date: Sat, 28 Feb 2026 14:50:04 +0800 Subject: [PATCH 2/3] =?UTF-8?q?feat:=20=E6=9B=B4=E6=96=B0=E6=96=87?= =?UTF-8?q?=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- public/docs/home.md | 38 ++++++++++++++++++++++++++++++++++---- 1 file changed, 34 insertions(+), 4 deletions(-) diff --git a/public/docs/home.md b/public/docs/home.md index b552ddf..a4cc0c9 100644 --- a/public/docs/home.md +++ b/public/docs/home.md @@ -1712,7 +1712,7 @@ tags: 歌单标签 7: 电台 ``` -`ids`: 资源 id 列表 , 多个 id 用逗号分隔 , 如 `123,456` +`ids`: 资源 id 列表 , 多个 id 用逗号分隔 , 如 `186016,347230` **接口地址 :** `/comment/info/list` @@ -1756,6 +1756,30 @@ tags: 歌单标签 **调用例子 :** `/comment/hot?id=186016&type=0` +**返回数据 :** + +```json +{ + "data": [ + { + "latestLikedUsers": null, + "liked": false, + "comments": null, + "resourceType": 4, + "resourceId": 186016, + "commentUpgraded": false, + "musicianSaidCount": 0, + "commentCountDesc": "100w+", + "likedCount": 347, + "commentCount": 1970844, + "shareCount": 109721, + "threadId": "R_SO_4_186016" + } + ], + "code": 200 +} +``` + ### 新版评论接口 说明 : 调用此接口 , 传入资源类型和资源 id,以及排序方式,可获取对应资源的评论 @@ -2815,12 +2839,14 @@ type : 地区 **1. 后端代理模式 (默认)** 文件通过服务器转发到云存储,调用简单,但受服务器限制: + - Vercel Serverless Functions 限制请求体大小为 4.5MB - 自建服务器需配置足够大的请求体限制 **2. 客户端直传模式 (推荐用于 Vercel)** 文件直接从客户端上传到云存储服务器,绕过服务器限制: + - 支持大文件上传 - 适合 Vercel、Netlify 等有请求体限制的平台 - 需要前端配合实现 @@ -2832,12 +2858,14 @@ type : 地区 **接口地址 :** `/cloud/upload/token` **必选参数 :** + - `cookie`: 网易云音乐 Cookie (在请求体中传递) - `md5`: 文件 MD5 值 - `fileSize`: 文件大小(字节) - `filename`: 文件名 **返回数据 :** + ```json { "code": 200, @@ -2856,6 +2884,7 @@ type : 地区 **接口地址 :** `/cloud/upload/complete` **必选参数 :** + - `cookie`: 网易云音乐 Cookie (在请求体中传递) - `songId`: 歌曲 ID - `resourceId`: 资源 ID @@ -2863,6 +2892,7 @@ type : 地区 - `filename`: 文件名 **可选参数 :** + - `song`: 歌曲名 - `artist`: 艺术家 - `album`: 专辑名 @@ -2890,6 +2920,7 @@ type : 地区 **调用例子 :** `/cloud/match?uid=32953014&sid=aaa&asid=bbb` `/cloud/match?uid=32953014&sid=bbb&asid=0` ### 获取云盘歌词 + 说明: 调用此接口, 获取云盘歌曲的歌词,歌词来自此文件的音乐元数据`LYRICS`标签。 **可选参数 :** @@ -4983,12 +5014,11 @@ let data = encodeURIComponent( **调用例子:** `/vip/sign/info` - ### 用户的创建歌单列表 说明 : 调用此接口, 传入用户id, 获取用户的创建歌单列表 -**必选参数 :** +**必选参数 :** `uid`: 用户 id @@ -5006,7 +5036,7 @@ let data = encodeURIComponent( 说明 : 调用此接口, 传入用户id, 获取用户的收藏歌单列表 -**必选参数 :** +**必选参数 :** `uid`: 用户 id From 1320e5780bfa70465b5e9d0cb94475f830a13826 Mon Sep 17 00:00:00 2001 From: imsyy Date: Sat, 28 Feb 2026 14:52:13 +0800 Subject: [PATCH 3/3] =?UTF-8?q?feat:=20=E6=9B=B4=E6=96=B0=E6=96=87?= =?UTF-8?q?=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- public/docs/home.md | 48 ++++++++++++++++++++++----------------------- 1 file changed, 24 insertions(+), 24 deletions(-) diff --git a/public/docs/home.md b/public/docs/home.md index a4cc0c9..c782a30 100644 --- a/public/docs/home.md +++ b/public/docs/home.md @@ -1718,6 +1718,30 @@ tags: 歌单标签 **调用例子 :** `/comment/info/list?type=0&ids=186016,347230` +**返回数据 :** + +```json +{ + "data": [ + { + "latestLikedUsers": null, + "liked": false, + "comments": null, + "resourceType": 4, + "resourceId": 186016, + "commentUpgraded": false, + "musicianSaidCount": 0, + "commentCountDesc": "100w+", + "likedCount": 347, + "commentCount": 1970844, + "shareCount": 109721, + "threadId": "R_SO_4_186016" + } + ], + "code": 200 +} +``` + ### 热门评论 说明 : 调用此接口 , 传入 type, 资源 id 可获得对应资源热门评论 ( 不需要登录 ) @@ -1756,30 +1780,6 @@ tags: 歌单标签 **调用例子 :** `/comment/hot?id=186016&type=0` -**返回数据 :** - -```json -{ - "data": [ - { - "latestLikedUsers": null, - "liked": false, - "comments": null, - "resourceType": 4, - "resourceId": 186016, - "commentUpgraded": false, - "musicianSaidCount": 0, - "commentCountDesc": "100w+", - "likedCount": 347, - "commentCount": 1970844, - "shareCount": 109721, - "threadId": "R_SO_4_186016" - } - ], - "code": 200 -} -``` - ### 新版评论接口 说明 : 调用此接口 , 传入资源类型和资源 id,以及排序方式,可获取对应资源的评论