README.md 52.8 KB
Newer Older
B
binaryify 已提交
1 2 3
# NeteaseCloudMusicApi

网易云音乐 NodeJS 版 API
B
binaryify 已提交
4

B
binaryify 已提交
5
## 灵感来自
B
improve  
binaryify 已提交
6

B
binaryify 已提交
7 8 9 10
[disoul/electron-cloud-music](https://github.com/disoul/electron-cloud-music)

[darknessomi/musicbox](https://github.com/darknessomi/musicbox)

11
[sqaiyan/netmusic-node](https://github.com/sqaiyan/netmusic-node)
B
binaryify 已提交
12

B
binaryify 已提交
13
## 工作原理
B
improve  
binaryify 已提交
14 15

跨站请求伪造 (CSRF), 伪造请求头 , 调用官方 API
B
binaryify 已提交
16

17
## 功能特性
B
improve  
binaryify 已提交
18

19
1. 登录
20
2. 刷新登录
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
3. 发送验证码
4. 校验验证码
5. 注册(修改密码)
6. 获取用户信息 , 歌单,收藏,mv, dj 数量
7. 获取用户歌单
8. 获取用户电台
9. 获取用户关注列表
10. 获取用户粉丝列表
11. 获取用户动态
12. 获取用户播放记录
13. 获取精品歌单
14. 获取歌单详情
15. 搜索
16. 搜索建议
17. 获取歌词
18. 歌曲评论
19. 收藏单曲到歌单
20. 专辑评论
21. 歌单评论
22. mv 评论
23. 电台节目评论
24. banner
25. 获取歌曲详情
26. 获取专辑内容
27. 获取歌手单曲
28. 获取歌手 mv
29. 获取歌手专辑
30. 获取歌手描述
31. 获取相似歌手
32. 获取相似歌单
33. 相似 mv
34. 获取相似音乐
35. 获取最近 5 个听了这首歌的用户
36. 获取每日推荐歌单
37. 获取每日推荐歌曲
38. 私人 FM
39. 签到
40. 喜欢音乐
41. 垃圾桶
42. 歌单 ( 网友精选碟 )
43. 新碟上架
44. 热门歌手
45. 最新 mv
46. 推荐 mv
47. 推荐歌单
48. 推荐新音乐
49. 推荐电台
50. 推荐节目
51. 独家放送
52. mv 排行
53. 获取 mv 数据
54. 播放 mv/视频
55. 排行榜
56. 歌手榜
57. 云盘
58. 电台 - 推荐
59. 电台 - 分类
60. 电台 - 分类推荐
61. 电台 - 订阅
62. 电台 - 详情
63. 电台 - 节目
64. 给评论点赞
65. 获取动态
66. 获取热搜
67. 发送私信
68. 发送私信歌单
69. 新建歌单
70. 收藏/取消收藏歌单
71. 歌单分类
72. 收藏的歌手列表
73. 订阅的电台列表
74. 相关歌单推荐
75. 付费精选接口
76. 音乐是否可用检查接口
77. 登录状态
78. 获取视频数据
79. 发送/删除评论
80. 热门评论
81. 视频评论
82. 退出登录
83. 所有榜单
84. 所有榜单内容摘要
85. 收藏视频
86. 收藏 MV
87. 视频详情
88. 相关视频
89. 关注用户
90. 新歌速递
91. 喜欢音乐列表(无序)
92. 收藏的 MV 列表
93. 获取最新专辑
94. 听歌打卡
95. 获取视频标签下的视频
96. 已收藏专辑列表
97. 获取动态评论
98. 歌单收藏者列表
117 118 119 120 121 122
99. 云盘歌曲删除
100. 热门话题
101. 电台 - 推荐类型
102. 电台 - 非热门类型
103. 电台 - 今日优选
104. 心动模式/智能播放
B
binaryify 已提交
123
105. 转发动态
B
binaryify 已提交
124
106. 删除动态
125
107. 分享歌曲、歌单、mv、电台、电台节目到动态
B
binaryify 已提交
126 127 128 129 130 131
108. 通知-私信
109. 通知-评论
110. 通知-@我
111. 通知-通知
112. 设置
113. 云盘数据详情
B
v3.12.0  
binaryify 已提交
132 133
114. 私信内容
115. 我的数字专辑
B
v3.0.0  
binaryify 已提交
134

B
improve  
binaryify 已提交
135
## 安装
B
improve  
binaryify 已提交
136 137

```shell
138
$ git clone git@github.com:Binaryify/NeteaseCloudMusicApi.git
139

140
$ npm install
B
binaryify 已提交
141
```
B
improve  
binaryify 已提交
142

143
## 运行
B
improve  
binaryify 已提交
144 145

```shell
N
nujhong 已提交
146
$ node app.js
B
binaryify 已提交
147 148
```

B
improve  
binaryify 已提交
149 150
服务器启动默认端口为 3000, 若不想使用 3000 端口 , 可使用以下命令 : Mac/Linux

B
binaryify 已提交
151 152 153 154
```shell
$ PORT=4000 node app.js
```

B
improve  
binaryify 已提交
155 156
windows 下使用 git-bash 或者 cmder 等终端执行以下命令 :

B
binaryify 已提交
157 158 159
```shell
$ set PORT=4000 && node app.js
```
B
binaryify 已提交
160

161 162 163 164 165 166
## 可以使用代理

在 query 参数中加上 proxy=your-proxy 即可让这一次的请求使用 proxy

```javascript
// 例子
B
v3.0.0  
binaryify 已提交
167
const url = `http://localhost:3000/song/url?id=33894312&proxy=http://121.196.226.246:84`
168 169 170 171 172 173 174
fetch(url).then(function() {
  // do what you want
})

// 结果
// {"data":[{"id":33894312,"url":"http://m10.music.126.net/20180104125640/930a968b3fb04908b733506b3833e60b/ymusic/0fd6/4f65/43ed/a8772889f38dfcb91c04da915b301617.mp3","br":320000,"size":10691439,"md5":"a8772889f38dfcb91c04da915b301617","code":200,"expi":1200,"type":"mp3","gain":-2.0E-4,"fee":0,"uf":null,"payed":0,"flag":0,"canExtend":false}],"code": 200}
```
175
v3.3.0 后支持使用 PAC代理,如 `?proxy=http://192.168.0.1/proxy.pac`
B
binaryify 已提交
176

B
binaryify 已提交
177
## 更新到 v3.0 说明
B
binaryify 已提交
178

B
binaryify 已提交
179
!>2018.10.14 更新到 3.0.0,使用了模块化机制,因为部分接口参数和 url 做了调整,如还不想升级到 3.0.0,请查看 [v2 的文档](http://binaryify.github.io/NeteaseCloudMusicApi/#/v2), [更新日志](https://github.com/Binaryify/NeteaseCloudMusicApi/blob/master/CHANGELOG.MD), [2.0+下载地址](https://github.com/Binaryify/NeteaseCloudMusicApi/releases/tag/v2.20.5), 同时 2.0+ 将不再维护
180

B
improve  
binaryify 已提交
181 182
## Docker 容器运行

B
binaryify 已提交
183
> 注意: 在 docker 中运行的时候, 由于使用了 request 来发请求, 所以会检查几个 proxy 相关的环境变量(如下所列), 这些环境变量 会影响到 request 的代理, 详情请参考[request 的文档](https://github.com/request/request#proxies), 如果这些环境变量 指向的代理不可用, 那么就会造成错误, 所以在使用 docker 的时候一定要注意这些环境变量. 不过, 要是你在 query 中加上了 proxy 参数, 那么环境变量会被覆盖, 就会用你通过 proxy 参数提供的代理了.
184 185 186

request 相关的环境变量

187 188 189 190 191 192 193
1. http_proxy
2. https_proxy
3. HTTP_PROXY
4. HTTPS_PROXY
5. no_proxy
6. NO_PROXY

194
```shell
B
binaryify 已提交
195
docker pull binaryify/netease_cloud_music_api
196

B
binaryify 已提交
197 198 199 200 201
docker run -d -p 3000:3000 --name netease_cloud_music_api    binaryify/netease_cloud_music_api


// 或者 
docker run -d -p 3000:3000 binaryify/netease_cloud_music_api
202 203

// 去掉或者设置相关的环境变量
204

B
binaryify 已提交
205 206 207 208
docker run -d -p 3000:3000 --name netease_cloud_music_api -e http_proxy= -e https_proxy= -e no_proxy= -e HTTP_PROXY= -e HTTPS_PROXY= -e NO_PROXY= binaryify/netease_cloud_music_api

// 或者
docker run -d -p 3000:3000 -e http_proxy= -e https_proxy= -e no_proxy= -e HTTP_PROXY= -e HTTPS_PROXY= -e NO_PROXY= binaryify/netease_cloud_music_api
209
```
B
binaryify 已提交
210

B
binaryify 已提交
211
> 以下是自行 build docker 镜像方式
212 213 214

```
$ git clone https://github.com/Binaryify/NeteaseCloudMusicApi && cd NeteaseCloudMusicApi
215

216
$ sudo docker build . -t netease-music-api
217

218 219
$ sudo docker run -d -p 3000:3000 netease-music-api
```
B
binaryify 已提交
220

221
## 接口文档
B
improve  
binaryify 已提交
222

B
binaryify 已提交
223
### 调用前须知
B
binaryify 已提交
224
!> 本项目不提供线上 demo,请不要轻易信任使用他人提供的公开服务,以免发生安全问题,泄露自己的账号和密码
B
improve  
binaryify 已提交
225

B
binaryify 已提交
226
!> 为使用方便,降低门槛, 文档示例接口直接使用了 GET 请求,本项目同时支持 GET/POST 请按实际需求使用
B
binaryify 已提交
227

B
binaryify 已提交
228
!> 由于接口做了缓存处理 ( 缓存 2 分钟,不缓存数据极容易引起网易服务器高频ip错误 , 可在 app.js 设置 , 可能会导致登陆后获取不到 cookie), **相同的 url** 会在两分钟内只向网易服务器发一次请求 , 如果遇到不需要缓
B
binaryify 已提交
229
存结果的接口 , 可在请求 url 后面加一个时间戳参数使 url 不同 , 例子 :
B
binaryify 已提交
230
`/simi/playlist?id=347230&timestamp=1503019930000` (之所以加入缓存机制是因为项目早期没有缓存机制,很多  issues 都是报 IP高频,请按自己需求改造缓存中间件(app.js),源码不复杂)
B
improve  
binaryify 已提交
231

B
binaryify 已提交
232 233
!> 如果是跨域请求 , 请在所有请求带上 `xhrFields: { withCredentials: true }` (axios 为 `withCredentials: true`)否则
可能会因为没带上 cookie 导致 301, 具体例子可看 `public/test.html`, 例子使用 jQuery 和 axios 
B
improve  
binaryify 已提交
234

B
binaryify 已提交
235
!> 301 错误基本都是没登录就调用了需要登录的接口,如果登陆了还是提示 301, 基本都是缓存把数据缓存起来了,解决方法是加时间戳或者等待 2 分钟或者重启服务重新登录后再调用接口,可自行改造缓存方法
B
binaryify 已提交
236

B
binaryify 已提交
237
!> 部分接口如登录接口不能调用太频繁 , 否则可能会触发 503 错误或者 ip 高频错误 ,若需频繁调用 , 需要准备 IP 代理池 (更新:已加入缓存机制,但仍需注意).
B
improve  
binaryify 已提交
238

B
binaryify 已提交
239 240 241
!> 本项目仅供学习使用,请尊重版权,请勿利用此项目从事商业行为

!> 文档可能会有缓存 , 如果文档版本和 github 上的版本不一致,请清除缓存再查看
B
improve  
binaryify 已提交
242

B
binaryify 已提交
243
!> 由于网易限制,此项目在国外服务器上使用会受到限制,如需解决 , 可使用大陆服务器或者使用代理 , 感谢 [@hiyangguo](https://github.com/hiyangguo)提出的[解决方法](https://github.com/Binaryify/NeteaseCloudMusicApi/issues/29#issuecomment-298358438):
B
binaryify 已提交
244 245
在 'util.js' 的 'headers' 处增加 `X-Real-IP':'211.161.244.70' // 任意国内 IP`
即可解决
B
binaryify 已提交
246 247

### 登录
B
improve  
binaryify 已提交
248 249 250

说明 : 登录有两个接口

B
improve  
binaryify 已提交
251
#### 1. 手机登录
252

B
improve  
binaryify 已提交
253
**必选参数 :** `phone`: 手机号码 `password`: 密码
254

B
improve  
binaryify 已提交
255
**接口地址 :** `/login/cellphone`
256

T
trazyn 已提交
257 258
**可选参数 :** `countrycode`: 国家码,用于国外手机号登陆,例如美国传入:`1`

B
improve  
binaryify 已提交
259
**调用例子 :** `/login/cellphone?phone=xxx&password=yyy`
260

B
improve  
binaryify 已提交
261
#### 2. 邮箱登录
B
binaryify 已提交
262

B
binaryify 已提交
263 264
~~ 注意 : 此接口被网易和谐了 , 待修复 , 暂时使用手机登录 (2017.05.20)~~

B
binaryify 已提交
265
> 更新 : 此接口已经可以正常使用(2018.07.03)
266

267 268
**必选参数 :** `email`: 163 网易邮箱  
`password`: 密码
269

B
improve  
binaryify 已提交
270
**接口地址 :** `/login`
271

B
improve  
binaryify 已提交
272
**调用例子 :** `/login?email=xxx@163.com&password=yyy`
B
binaryify 已提交
273

B
improve  
binaryify 已提交
274 275
返回数据如下图 :
![登录](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E7%99%BB%E5%BD%95.png)
B
binaryify 已提交
276

B
improve  
binaryify 已提交
277 278
完成登录后 , 会在浏览器保存一个 Cookies 用作登录凭证 , 大部分 API 都需要用到这个
Cookies
B
binaryify 已提交
279

B
binaryify 已提交
280
#### 注意
B
improve  
binaryify 已提交
281 282

调用登录接口的速度比调用其他接口慢 , 因为登录过程调用了加密算法
B
binaryify 已提交
283

284
### 刷新登录
N
nujhong 已提交
285

B
improve  
binaryify 已提交
286 287 288
说明 : 调用此接口 , 可刷新登录状态

**调用例子 :** `/login/refresh`
289

290 291 292 293 294 295 296 297 298 299 300
### 发送验证码

说明 : 调用此接口 ,传入手机号码, 可发送验证码

**必选参数 :** `phone`: 手机号码  

**可选参数 :**
`ctcode`:  国家区号,默认86即中国

**接口地址 :** `/captch/sent`

B
binaryify 已提交
301
**调用例子 :** `/captch/sent?phone=13xxx`
302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339



### 验证验证码

说明 : 调用此接口 ,传入手机号码和验证码, 可校验验证码是否正确

**必选参数 :** `phone`: 手机号码  

`captcha`: 验证码

**可选参数 :**

`ctcode`:  国家区号,默认86即中国

**接口地址 :** `/captch/verify`

**调用例子 :** `/captch/verify?phone=13xxx&captcha=1597`


### 注册(修改密码)

说明 : 调用此接口 ,传入手机号码和验证码,密码,昵称, 可注册网易云音乐账号(同时可修改密码)

**必选参数 :** `phone`: 手机号码  

`captcha`: 验证码

`phone` :  手机号码 

`password`: 密码

`nickname`: 昵称

**接口地址 :** `/captch/register`

**调用例子 :** `/captch/register?phone=13xxx&password=xxxxx&captcha=1234&nickname=binary1345`

B
v2.20.3  
binaryify 已提交
340 341 342 343 344 345
### 退出登录

说明 : 调用此接口 , 可退出登录

**调用例子 :** `/logout`

346
### 登录状态
B
binaryify 已提交
347

348 349 350 351 352 353
说明 : 调用此接口,可获取登录状态

**接口地址 :** `/login/status`
返回数据如下图:
![数据](https://ws2.sinaimg.cn/large/006tNbRwgy1fup6q18kk6j316i0nw0wa.jpg)

B
binaryify 已提交
354 355
### 获取用户详情

B
improve  
binaryify 已提交
356
说明 : 登陆后调用此接口 , 传入用户 id, 可以获取用户详情
B
binaryify 已提交
357

B
improve  
binaryify 已提交
358
**必选参数 :** `uid` : 用户 id
B
binaryify 已提交
359

B
improve  
binaryify 已提交
360
**接口地址 :** `/user/detail`
B
binaryify 已提交
361

B
improve  
binaryify 已提交
362
**调用例子 :** `/user/detail?uid=32953014`
B
binaryify 已提交
363

B
improve  
binaryify 已提交
364
### 获取用户信息 , 歌单,收藏,mv, dj 数量
365

B
improve  
binaryify 已提交
366
说明 : 登陆后调用此接口 , 可以获取用户信息
367

B
improve  
binaryify 已提交
368
**接口地址 :** `/user/subcount`
369

B
improve  
binaryify 已提交
370
**调用例子 :** `/user/subcount`
371

372 373 374 375 376
### 更新用户信息

说明 : 登陆后调用此接口 , 传入相关信息,可以更新用户信息

**必选参数 :**
B
binaryify 已提交
377

378 379
```
gender: 性别 0:保密 1:男性 2:女性
380

381
birthday: 出生日期,时间戳 unix timestamp
382

383
nickname: 用户昵称
384

385
province: 省份id
386

387
city: 城市id
388

389 390 391 392 393 394 395
signature:用户签名
```

**接口地址 :** `/user/subcount`

**调用例子 :** `/user/update/?gender=0&signature=测试签名&city=440300&nickname=binary&birthday=1525918298004&province=440000`

B
binaryify 已提交
396
### 获取用户歌单
397

B
improve  
binaryify 已提交
398
说明 : 登陆后调用此接口 , 传入用户 id, 可以获取用户歌单
399

B
improve  
binaryify 已提交
400
**必选参数 :** `uid` : 用户 id
401

B
improve  
binaryify 已提交
402
**接口地址 :** `/user/playlist`
403

B
improve  
binaryify 已提交
404 405 406
**调用例子 :** `/user/playlist?uid=32953014`

返回数据如下图 :
B
binaryify 已提交
407 408
![用户歌单](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E7%94%A8%E6%88%B7%E6%AD%8C%E5%8D%95.png)

409 410 411 412
### 更新歌单

说明 : 登陆后调用此接口,可以更新用户歌单
参数:
B
binaryify 已提交
413

414 415
```
id:歌单id
416

B
binaryify 已提交
417
name:歌单名字=
418

419
desc:歌单描述
420

421 422
tags:歌单tag
```
B
binaryify 已提交
423

424 425 426 427
**接口地址 :** `/playlist/update`

**调用例子 :** `/playlist/update/?id=24381616&name=新歌单&desc=描述&tags=学习`

428 429
### 获取用户电台

B
improve  
binaryify 已提交
430 431 432
说明 : 登陆后调用此接口 , 传入用户 id, 可以获取用户电台

**必选参数 :** `uid` : 用户 id
433

B
improve  
binaryify 已提交
434
**接口地址 :** `/user/dj`
435

B
improve  
binaryify 已提交
436
**调用例子 :** `/user/dj?uid=32953014`
437

B
improve  
binaryify 已提交
438
### 获取用户关注列表
439

B
improve  
binaryify 已提交
440 441 442
说明 : 登陆后调用此接口 , 传入用户 id, 可以获取用户关注列表

**必选参数 :** `uid` : 用户 id
N
nujhong 已提交
443

B
binaryify 已提交
444
**可选参数 :**
445

B
binaryify 已提交
446 447 448
`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 , 如
B
improve  
binaryify 已提交
449
: 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0
450

B
improve  
binaryify 已提交
451
**接口地址 :** `/user/follows`
452

B
improve  
binaryify 已提交
453
**调用例子 :** `/user/follows?uid=32953014`
454

B
improve  
binaryify 已提交
455
### 获取用户粉丝列表
456

B
improve  
binaryify 已提交
457
说明 : 登陆后调用此接口 , 传入用户 id, 可以获取用户粉丝列表
458

B
improve  
binaryify 已提交
459
**必选参数 :** `uid` : 用户 id
460

B
improve  
binaryify 已提交
461 462
**可选参数 :** `limit` : 返回数量 , 默认为 30 `offset` : 偏移数量,用于分页 , 如
: 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0
463

B
improve  
binaryify 已提交
464 465 466
**接口地址 :** `/user/followeds`

**调用例子 :** `/user/followeds?uid=32953014`
467 468 469

### 获取用户动态

B
improve  
binaryify 已提交
470 471 472
说明 : 登陆后调用此接口 , 传入用户 id, 可以获取用户动态

**必选参数 :** `uid` : 用户 id
473

B
improve  
binaryify 已提交
474
**接口地址 :** `/user/event`
475

B
improve  
binaryify 已提交
476
**调用例子 :** `/user/event?uid=32953014`
477

B
binaryify 已提交
478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494
### 转发用户动态
说明 : 登陆后调用此接口 ,可以转发用户动态

**必选参数 :** `uid` : 用户 id  

`evId` : 动态 id  

`forwards` : 转发的评论

**接口地址 :** `/event/forward`

**调用例子 :** `/event/forward?evId=6712917601&uid=32953014&forwards=测试内容`

如下图
![](https://ws4.sinaimg.cn/large/006tNc79gy1g2trwz8o2gj31b20r6t9n.jpg)
![](https://ws3.sinaimg.cn/large/006tNc79gy1g2trxa0vlej319u0gyjrq.jpg)

B
binaryify 已提交
495 496 497 498 499 500 501 502 503
### 删除用户动态
说明 : 登陆后调用此接口 ,可以删除用户动态

**必选参数 :** `evId` :  动态 id  

**接口地址 :** `/event/del`

**调用例子 :** `/event/del?evId=6712917601`

504 505 506 507 508 509 510 511 512 513 514 515 516
### 分享歌曲、歌单、mv、电台、电台节目到动态
说明 : 登陆后调用此接口 ,可以分享歌曲、歌单、mv、电台、电台节目到动态

**必选参数 :** `id` :   资源 id  (歌曲,歌单,mv,电台,电台节目对应 id)

**可选参数 :** `type`: 资源类型,默认歌曲 song,可传 `song`,`playlist`,`mv`,`djradio`,`djprogram`

`msg`: 内容,140 字限制,支持 emoji,@用户名(`/user/follows`接口获取的用户名,用户名后和内容应该有空格),图片暂不支持

**接口地址 :** `/share/resource`

**调用例子 :** `/share/resource?id=1297494209&msg=测试` `/share/resource?type=djradio&id=336355127` `/share/resource?type=djprogram&id=2061034798` `/share/resource?type=djprogram&id=2061034798&msg=测试@binaryify 测试` 

517 518 519 520 521 522
### 获取动态评论

说明 : 登陆后调用此接口 , 可以获取动态下评论

**必选参数 :** `threadId` : 动态 id,可通过 `/event``/user/event` 接口获取

523
**接口地址 :** `/comment/event`
524

525
**调用例子 :** `/comment/event?threadId=A_EV_2_6559519868_32953014`
526

B
v3.0.0  
binaryify 已提交
527 528 529 530 531 532
### 关注/取消关注用户

说明 : 登陆后调用此接口 , 传入用户 id, 和操作 t,可关注/取消关注用户

**必选参数 :**

B
binaryify 已提交
533
`id` : 用户 id
B
v3.0.0  
binaryify 已提交
534

B
binaryify 已提交
535
`t` : `1`为关注,其他为取消关注
B
v3.0.0  
binaryify 已提交
536 537 538 539 540

**接口地址 :** `/follow`

**调用例子 :** `/follow?id=32953014&t=1`

541 542
### 获取用户播放记录

B
improve  
binaryify 已提交
543 544 545
说明 : 登陆后调用此接口 , 传入用户 id, 可获取用户播放记录

**必选参数 :** `uid` : 用户 id
546

B
improve  
binaryify 已提交
547
**可选参数 :** `type` : type=1 时只返回 weekData, type=0 时返回 allData
548

B
improve  
binaryify 已提交
549
**接口地址 :** `/user/record`
550

B
improve  
binaryify 已提交
551
**调用例子 :** `/user/record?uid=32953014&type=1`
552

553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577
### 获取热门话题

说明 : 调用此接口 , 可获取热门话题

**可选参数 :** `limit`: 取出评论数量 , 默认为 20

`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值

**接口地址 :** `/act/hot`

**调用例子 :** `/act/hot?limit=30&offset=30`

### 心动模式/智能播放
说明 : 调用此接口 , 可获取心动模式/智能播放列表
**必选参数 :** `id` : 歌曲 id

`pid` : 歌单 id

**可选参数 :**
`sid` : 要开始播放的歌曲的 id

**接口地址 :** `/playmode/intelligence/list`

**调用例子 :** `/playmode/intelligence/list?id=33894312&pid=24381616` , `/playmode/intelligence/list?id=33894312&pid=24381616&sid=36871368`

Z
zhixuan 已提交
578 579
### 获取动态消息

B
improve  
binaryify 已提交
580 581
说明 : 调用此接口 , 可获取各种动态 , 对应网页版网易云,朋友界面里的各种动态消息
,如分享的视频,音乐,照片等!
Z
zhixuan 已提交
582

583 584 585 586
**必选参数 :** 
`pagesize` : 每页数据,默认20

`lasttime` : 返回数据的 `lasttime` ,默认-1,传入上一次返回结果的 lasttime,将会返回下一页的数据
Z
zhixuan 已提交
587

B
improve  
binaryify 已提交
588 589
**接口地址 :** `/event`

590
**调用例子 :** `/event?pagesize=30&lasttime=1556740526369`
Z
zhixuan 已提交
591

592
### 歌手分类列表
B
binaryify 已提交
593

594 595 596
说明 : 调用此接口,可获取歌手分类列表
**必选参数 :** `cat` : 即 category Code,歌手类型,默认 1001,返回华语男歌手数据
**可选参数 :**
597

598 599 600 601
`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 , 如
: 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0
B
binaryify 已提交
602
`initial`: 按首字母索引查找参数,如 `/artist/list?cat=1001&initial=b` 返回内容将以 name 字段开头为 b 或者拼音开头为 b 为顺序排列
603

604
category Code 取值:
B
binaryify 已提交
605

606 607
```
入驻歌手 5001
608

609
华语男歌手 1001
610

611
华语女歌手 1002
612

613
华语组合/乐队 1003
614

615
欧美男歌手 2001
616

617
欧美女歌手 2002
618

619
欧美组合/乐队 2003
620

621
日本男歌手 6001
622

623
日本女歌手 6002
624

625
日本组合/乐队 6003
626

627
韩国男歌手 7001
628

629
韩国女歌手 7002
630

631
韩国组合/乐队 7003
632

633
其他男歌手 4001
634

635
其他女歌手 4002
636

637 638 639 640 641 642 643 644 645 646
其他组合/乐队 4003
```

**接口地址 :** `/artist/list`

**调用例子 :** `/artist/list?cat=1001`

返回数据如下图:
![数据](https://ws1.sinaimg.cn/large/006tKfTcgy1fr60g9zps9j31kw1bpk4n.jpg)

B
v3.0.0  
binaryify 已提交
647
### 收藏/取消收藏歌手
B
binaryify 已提交
648

B
binaryify 已提交
649
说明 : 调用此接口,可收藏歌手
B
v3.0.0  
binaryify 已提交
650

B
binaryify 已提交
651
**必选参数 :**
652

B
binaryify 已提交
653
`artistId` : 歌手 id
654

B
binaryify 已提交
655
`t`:操作,1 为收藏,其他为取消收藏
B
binaryify 已提交
656

B
v3.0.0  
binaryify 已提交
657
**接口地址 :** `/artist/sub`
658

B
v3.0.0  
binaryify 已提交
659
**调用例子 :** `/artist/sub?id=6452&t=1`
660

661
### 收藏的歌手列表
B
binaryify 已提交
662

663 664 665 666 667 668
说明 : 调用此接口,可获取收藏的歌手列表

**接口地址 :** `/artist/sublist`

**调用例子 :** `/artist/sublist`

B
v3.0.0  
binaryify 已提交
669 670 671 672
### 收藏视频

说明 : 调用此接口,可收藏视频

B
binaryify 已提交
673
**必选参数 :**
B
v3.0.0  
binaryify 已提交
674 675 676 677 678 679 680 681 682 683 684 685 686

`id` : 视频 id

`t` : 1 为收藏,其他为取消收藏

**接口地址 :** `/video/sub`

**调用例子 :** `/video/sub`

### 收藏 MV

说明 : 调用此接口,可收藏 MV

B
binaryify 已提交
687
**必选参数 :**
B
v3.0.0  
binaryify 已提交
688 689 690 691 692 693 694 695 696

`id` : MV id

`t` : 1 为收藏,其他为取消收藏

**接口地址 :** `/mv/sub`

**调用例子 :** `/mv/sub`

697 698 699 700 701 702 703 704
### 收藏的 MV 列表

说明 : 调用此接口,可获取收藏的 MV 列表

**接口地址 :** `/mv/sublist`

**调用例子 :** `/mv/sublist`

B
binaryify 已提交
705
### 歌单分类
B
binaryify 已提交
706

B
binaryify 已提交
707 708 709 710 711 712 713
说明 : 调用此接口,可获取歌单分类,包含 category 信息

**接口地址 :** `/playlist/catlist`

**调用例子 :** `/playlist/catlist`

### 热门歌单分类
B
binaryify 已提交
714

B
binaryify 已提交
715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737
说明 : 调用此接口,可获取歌单分类,包含 category 信息

**接口地址 :** `/playlist/hot`

**调用例子 :** `/playlist/hot`

### 歌单 ( 网友精选碟 )

说明 : 调用此接口 , 可获取网友精选碟歌单

**可选参数 :** `order`: 可选值为 'new' 和 'hot', 分别对应最新和最热 , 默认为
'hot'

`cat`:`cat`: tag, 比如 " 华语 "、" 古风 " 、" 欧美 "、" 流行 ", 默认为
"全部",可从歌单分类接口获取(/playlist/catlist)

**接口地址 :** `/top/playlist`

**调用例子 :** `/top/playlist?limit=10&order=new`

返回数据如下图 :

![精选碟](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/top_playlist.png)
738

B
binaryify 已提交
739
![对应位置](https://ws2.sinaimg.cn/large/006tKfTcgy1fr3wnpyg6jj317e0vcqdc.jpg)
740

B
binaryify 已提交
741 742
![返回数据](https://ws4.sinaimg.cn/large/006tKfTcgy1fr3wqs5lw9j31ic1re4c4.jpg)

B
improve  
binaryify 已提交
743
### 获取精品歌单
744

B
improve  
binaryify 已提交
745
说明 : 调用此接口 , 可获取精品歌单
746

B
improve  
binaryify 已提交
747
**可选参数 :** `cat`: tag, 比如 " 华语 "、" 古风 " 、" 欧美 "、" 流行 ", 默认为
B
binaryify 已提交
748
"全部",可从歌单分类接口获取(/playlist/catlist)
749

B
improve  
binaryify 已提交
750
`limit`: 取出歌单数量 , 默认为 20
751

B
v3.0.0  
binaryify 已提交
752 753
`before`: 分页参数,取上一页最后一个歌单的 `updateTime` 获取下一页数据

B
improve  
binaryify 已提交
754
**接口地址 :** `/top/playlist/highquality`
755

B
v3.0.0  
binaryify 已提交
756
**调用例子 :** `http://localhost:3000/top/playlist/highquality?before=1503639064232&limit=3`
757

B
binaryify 已提交
758 759 760 761 762 763 764 765 766 767
### 相关歌单推荐

说明 : 调用此接口,传入歌单 id 可获取相关歌单(对应页面 [https://music.163.com/#/playlist?id=1](https://music.163.com/#/playlist?id=1))

**必选参数 :** `id` : 歌单 id

**接口地址 :** `/related/playlist`

**调用例子 :** `/related/playlist?id=1`

B
improve  
binaryify 已提交
768
### 获取歌单详情
769

B
improve  
binaryify 已提交
770
说明 : 歌单能看到歌单名字 , 但看不到具体歌单内容 , 调用此接口 , 传入歌单 id, 可
771
以获取对应歌单内的所有的音乐,但是返回的trackIds是完整的,tracks 则是不完整的,可拿全部 trackIds 请求一次 `song/detail` 接口获取所有歌曲的详情 ([https://github.com/Binaryify/NeteaseCloudMusicApi/issues/452](https://github.com/Binaryify/NeteaseCloudMusicApi/issues/452))
B
improve  
binaryify 已提交
772 773

**必选参数 :** `id` : 歌单 id
774

B
binaryify 已提交
775
**可选参数 :** `s` : 歌单最近的 s 个收藏者
B
binaryify 已提交
776

B
improve  
binaryify 已提交
777
**接口地址 :** `/playlist/detail`
778

B
improve  
binaryify 已提交
779
**调用例子 :** `/playlist/detail?id=24381616`
780

B
improve  
binaryify 已提交
781
返回数据如下图 :
B
binaryify 已提交
782 783 784
![歌单详情](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E6%AD%8C%E5%8D%95%E8%AF%A6%E6%83%85.png)

### 获取音乐 url
785

B
improve  
binaryify 已提交
786 787 788 789 790
说明 : 使用歌单详情接口后 , 能得到的音乐的 id, 但不能得到的音乐 url, 调用此接口
, 传入的音乐 id( 可多个 , 用逗号隔开 ), 可以获取对应的音乐的 url( 不需要登录 )

> 注 : 部分用户反馈获取的 url 会 403,[hwaphon](https://github.com/hwaphon)找到的
> 解决方案是当获取到音乐的 id 后,将
791
> https://music.163.com/song/media/outer/url?id=id.mp3 以 src 赋予 Audio 即可播放
B
binaryify 已提交
792

B
improve  
binaryify 已提交
793
**必选参数 :** `id` : 音乐 id
794

B
binaryify 已提交
795
**可选参数 :** `br`: 码率,默认设置了 999000 即最大码率,如果要 320k 则可设置为 320000,其他类推
B
binaryify 已提交
796

B
v3.0.0  
binaryify 已提交
797
**接口地址 :** `/song/url`
798

B
v3.0.0  
binaryify 已提交
799
**调用例子 :** `/song/url?id=33894312` `/song/url?id=405998841,33894312`
800

B
improve  
binaryify 已提交
801
返回数据如下图 :
B
binaryify 已提交
802 803
![音乐 url](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E9%9F%B3%E4%B9%90%20url.png)

804
### 音乐是否可用
B
binaryify 已提交
805

806 807 808 809
说明: 调用此接口,传入歌曲 id, 可获取音乐是否可用,返回 `{ success: true, message: 'ok' }` 或者 `{ success: false, message: '亲爱的,暂无版权' }`

**必选参数 :** `id` : 歌曲 id

B
binaryify 已提交
810
**可选参数** : `br`: 码率,默认设置了 999000 即最大码率,如果要 320k 则可设置为 320000,其他类推
811 812 813 814 815

**接口地址 :** `/check/music`

**调用例子 :** `/check/music?id=33894312`

816
### 搜索
817

B
improve  
binaryify 已提交
818 819
说明 : 调用此接口 , 传入搜索关键词可以搜索该音乐 / 专辑 / 歌手 / 歌单 / 用户 ,
关键词可以多个 , 以空格隔开 , 如 " 周杰伦 搁浅 "( 不需要登录 ), 搜索获取的
B
v3.0.0  
binaryify 已提交
820
mp3url 不能直接用 , 可通过 `/song/url` 接口传入歌曲 id 获取具体的播放链接
821

B
improve  
binaryify 已提交
822
**必选参数 :** `keywords` : 关键词
823

B
improve  
binaryify 已提交
824 825
**可选参数 :** `limit` : 返回数量 , 默认为 30 `offset` : 偏移数量,用于分页 , 如
: 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0
N
nujhong 已提交
826

827 828
`type`: 搜索类型;默认为 1 即单曲 , 取值意义 : 1: 单曲, 10: 专辑, 100: 歌手, 1000:
歌单, 1002: 用户, 1004: MV, 1006: 歌词, 1009: 电台, 1014: 视频
N
nujhong 已提交
829

B
improve  
binaryify 已提交
830
**接口地址 :** `/search`
831

B
improve  
binaryify 已提交
832
**调用例子 :** `/search?keywords= 海阔天空`
833

B
improve  
binaryify 已提交
834
返回数据如下图 :
B
binaryify 已提交
835 836
![搜索音乐](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E6%90%9C%E7%B4%A2.png)

B
binaryify 已提交
837
### 热搜
B
binaryify 已提交
838

B
binaryify 已提交
839 840 841 842 843 844
说明 : 调用此接口,可获取热门搜索列表

**接口地址 :** `/search/hot`

**调用例子 :** `/search/hot`

845 846
### 搜索建议

B
improve  
binaryify 已提交
847
说明 : 调用此接口 , 传入搜索关键词可获得搜索建议 , 搜索结果同时包含单曲 , 歌手 ,
B
improve  
binaryify 已提交
848
歌单 ,mv 信息
849

B
improve  
binaryify 已提交
850
**必选参数 :** `keywords` : 关键词
N
nujhong 已提交
851

852 853
**可选参数 :** `type` : 如果传 'mobile' 则返回移动端数据

B
improve  
binaryify 已提交
854
**接口地址 :** `/search/suggest`
855

856
**调用例子 :** `/search/suggest?keywords= 海阔天空` `/search/suggest?keywords= 海阔天空&type=mobile`
857

B
binaryify 已提交
858 859
### 搜索多重匹配

B
improve  
binaryify 已提交
860 861 862
说明 : 调用此接口 , 传入搜索关键词可获得搜索结果

**必选参数 :** `keywords` : 关键词
N
nujhong 已提交
863

B
improve  
binaryify 已提交
864
**接口地址 :** `/search/multimatch`
B
binaryify 已提交
865

B
improve  
binaryify 已提交
866
**调用例子 :** `/search/multimatch?keywords= 海阔天空`
B
binaryify 已提交
867

868 869 870 871
### 新建歌单

说明 : 调用此接口 , 传入歌单名字可新建歌单

B
binaryify 已提交
872
**必选参数 :** `name` : 歌单名
873

B
v3.12.0  
binaryify 已提交
874 875
**可选参数 :** `privacy` : 是否设置为隐私歌单,默认否,传'10'则设置成隐私歌单

876 877 878 879 880 881 882 883 884 885 886 887
**接口地址 :** `/playlist/create`

**调用例子 :** `/playlist/create?name=测试歌单`

返回数据如下图:
![数据](https://ws1.sinaimg.cn/large/006tKfTcgy1fr3va885z5j31a617qwjy.jpg)

### 收藏/取消收藏歌单

说明 : 调用此接口 , 传入类型和歌单 id 可收藏歌单或者取消收藏歌单

**必选参数 :**
888

B
binaryify 已提交
889
`t` : 类型,1:收藏,2:取消收藏
890 891 892 893 894 895 896 897 898
`id` : 歌单 id

**接口地址 :** `/playlist/subscribe`

**调用例子 :** `/playlist/subscribe?t=1&id=106697785` `/playlist/subscribe?t=2&id=106697785`

返回数据如下图:
![数据](https://ws1.sinaimg.cn/large/006tKfTcgy1fr3vdwx0hvj30s405u74b.jpg)

899 900 901 902 903 904 905 906 907 908 909 910 911 912 913
### 歌单收藏者
说明 : 调用此接口 , 传入歌单 id 可获取歌单的所有收藏者  
**必选参数 :**

`id` : 歌单 id

**可选参数 :** `limit`: 取出评论数量 , 默认为 20

`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值

**接口地址 :** `/playlist/subscribers`

**调用例子 :** `/playlist/subscribers?id=544215255&limit=30`


914
### 对歌单添加或删除歌曲
B
binaryify 已提交
915

B
improve  
binaryify 已提交
916
说明 : 调用此接口 , 可以添加歌曲到歌单或者从歌单删除某首歌曲 ( 需要登录 )
B
binaryify 已提交
917

918
**必选参数 :**
919

920 921 922 923
`op`: 从歌单增加单曲为 add, 删除为 del

`pid`: 歌单 id
`tracks`: 歌曲 id,可多个,用逗号隔开
B
binaryify 已提交
924

B
improve  
binaryify 已提交
925
**接口地址 :** `/playlist/tracks`
B
binaryify 已提交
926

B
binaryify 已提交
927
**调用例子 :** `/playlist/tracks?op=add&pid=24381616&tracks=347231` ( 对应把歌曲添加到 ' 我 ' 的歌单 , 测试的时候请把这里的 pid 换成你自己的, id 和 tracks 不对可能会报 502 错误)
928

B
binaryify 已提交
929
### 获取歌词
930

B
improve  
binaryify 已提交
931
说明 : 调用此接口 , 传入音乐 id 可获得对应音乐的歌词 ( 不需要登录 )
932

B
improve  
binaryify 已提交
933
**必选参数 :** `id`: 音乐 id
934

B
improve  
binaryify 已提交
935
**接口地址 :** `/lyric`
936

B
improve  
binaryify 已提交
937 938 939
**调用例子 :** `/lyric?id=33894312`

返回数据如下图 :
940
![获取歌词](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E6%AD%8C%E8%AF%8D.png)
B
binaryify 已提交
941

B
binaryify 已提交
942 943 944 945 946 947 948 949 950 951
### 新歌速递

说明 : 调用此接口 , 可获取新歌速递

**必选参数 :**

`type`: 地区类型 id,对应以下:

```
全部:0
952

B
binaryify 已提交
953
华语:7
954

B
binaryify 已提交
955
欧美:96
956

B
binaryify 已提交
957
日本:8
958

B
binaryify 已提交
959 960 961 962 963 964 965
韩国:16
```

**接口地址 :** `/top/song`

**调用例子 :** `/top/song?type=96`

966
### 歌曲评论
967

B
improve  
binaryify 已提交
968 969
说明 : 调用此接口 , 传入音乐 id 和 limit 参数 , 可获得该音乐的所有评论 ( 不需要
登录 )
970

B
improve  
binaryify 已提交
971
**必选参数 :** `id`: 音乐 id
972

B
improve  
binaryify 已提交
973
**可选参数 :** `limit`: 取出评论数量 , 默认为 20
974

B
improve  
binaryify 已提交
975
`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值
976

B
improve  
binaryify 已提交
977
**接口地址 :** `/comment/music`
978

B
improve  
binaryify 已提交
979
**调用例子 :** `/comment/music?id=186016&limit=1` 对应晴天评论
980

B
improve  
binaryify 已提交
981 982
返回数据如下图 :
![获取评论](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/comment.png)
983 984 985

### 专辑评论

B
improve  
binaryify 已提交
986 987
说明 : 调用此接口 , 传入音乐 id 和 limit 参数 , 可获得该专辑的所有评论 ( 不需要
登录 )
988

B
improve  
binaryify 已提交
989
**必选参数 :** `id`: 专辑 id
990

B
improve  
binaryify 已提交
991
**可选参数 :** `limit`: 取出评论数量 , 默认为 20
992

B
improve  
binaryify 已提交
993
`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值
994

B
improve  
binaryify 已提交
995 996 997
**接口地址 :** `/comment/album`

**调用例子 :** `/comment/album?id=32311`
998 999 1000

### 歌单评论

B
improve  
binaryify 已提交
1001 1002 1003 1004
说明 : 调用此接口 , 传入音乐 id 和 limit 参数 , 可获得该歌单的所有评论 ( 不需要
登录 )

**必选参数 :** `id`: 歌单 id
1005

B
improve  
binaryify 已提交
1006
**可选参数 :** `limit`: 取出评论数量 , 默认为 20
1007

B
improve  
binaryify 已提交
1008
`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值
1009

B
improve  
binaryify 已提交
1010
**接口地址 :** `/comment/playlist`
1011

B
improve  
binaryify 已提交
1012
**调用例子 :** `/comment/playlist?id=705123491`
1013 1014 1015

### mv 评论

B
improve  
binaryify 已提交
1016 1017
说明 : 调用此接口 , 传入音乐 id 和 limit 参数 , 可获得该 mv 的所有评论 ( 不需要
登录 )
1018

B
improve  
binaryify 已提交
1019
**必选参数 :** `id`: mv id
1020

B
improve  
binaryify 已提交
1021
**可选参数 :** `limit`: 取出评论数量 , 默认为 20
1022

B
improve  
binaryify 已提交
1023
`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值
1024

B
improve  
binaryify 已提交
1025 1026 1027
**接口地址 :** `/comment/mv`

**调用例子 :** `/comment/mv?id=5436712`
1028 1029 1030

### 电台节目评论

B
improve  
binaryify 已提交
1031 1032 1033 1034
说明 : 调用此接口 , 传入音乐 id 和 limit 参数 , 可获得该 电台节目 的所有评论 (
不需要登录 )

**必选参数 :** `id`: 电台节目的 id
1035

B
improve  
binaryify 已提交
1036
**可选参数 :** `limit`: 取出评论数量 , 默认为 20
1037

B
improve  
binaryify 已提交
1038
`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值
1039

B
improve  
binaryify 已提交
1040
**接口地址 :** `/comment/dj`
1041

B
improve  
binaryify 已提交
1042
**调用例子 :** `/comment/dj?id=794062371`
1043

1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059
### 视频评论

说明 : 调用此接口 , 传入音乐 id 和 limit 参数 , 可获得该 视频 的所有评论 (
不需要登录 )

**必选参数 :** `id`: 视频的 id

**可选参数 :** `limit`: 取出评论数量 , 默认为 20

`offset`: 偏移数量 , 用于分页 , 如 :( 评论页数 -1)\*20, 其中 20 为 limit 的值

**接口地址 :** `/comment/video`

**调用例子 :** `/comment/video?id=89ADDE33C0AAE8EC14B99F6750DB954D`

### 热门评论
B
v2.20.3  
binaryify 已提交
1060 1061

说明 : 调用此接口 , 传入 type, 资源 id 可获得对应资源热门评论 ( 不需要登录 )
1062 1063 1064 1065 1066 1067 1068 1069 1070

**必选参数 :**

`id` : 资源 id

`tpye`: 数字 , 资源类型 , 对应歌曲 , mv, 专辑 , 歌单 , 电台, 视频对应以下类型

```
0: 歌曲
1071

1072
1: mv
1073

1074
2: 歌单
1075

1076
3: 专辑
1077

1078
4: 电台
1079

1080 1081
5: 视频
```
B
v2.20.3  
binaryify 已提交
1082

1083 1084 1085 1086
**接口地址 :** `/comment/hot`

**调用例子 :** `/comment/hot?id=186016&type=0`

B
binaryify 已提交
1087 1088
### 给评论点赞

B
improve  
binaryify 已提交
1089 1090 1091 1092
说明 : 调用此接口 , 传入 type, 资源 id, 和评论 id cid 和 是否点赞参数 t 即可给对
应评论点赞 ( 需要登录 )

**必选参数 :** `id` : 资源 id, 如歌曲 id,mv id
B
binaryify 已提交
1093

B
improve  
binaryify 已提交
1094
`cid` : 评论 id
B
binaryify 已提交
1095

B
improve  
binaryify 已提交
1096
`t` : 是否点赞 ,1 为点赞 ,0 为取消点赞
B
binaryify 已提交
1097

1098
`tpye`: 数字 , 资源类型 , 对应歌曲 , mv, 专辑 , 歌单 , 电台, 视频对应以下类型
B
binaryify 已提交
1099

B
binaryify 已提交
1100 1101
```
0: 歌曲
1102

B
binaryify 已提交
1103
1: mv
1104

B
binaryify 已提交
1105
2: 歌单
1106

N
nujhong 已提交
1107
3: 专辑
1108

B
binaryify 已提交
1109
4: 电台
1110

1111
5: 视频
1112 1113

6: 动态
B
improve  
binaryify 已提交
1114
```
N
nujhong 已提交
1115

B
improve  
binaryify 已提交
1116
**接口地址 :** `comment/like`
B
binaryify 已提交
1117

B
binaryify 已提交
1118
**调用例子 :** `/comment/like?id=29178366&cid=12840183&t=1&type=0` 对应给 [https://music.163.com/#/song?id=29178366](https://music.163.com/#/song?id=29178366) 最热门的评论点赞
B
binaryify 已提交
1119

1120 1121 1122

注意: 动态点赞不需要传入 id 参数,需要传入动态的 `threadId`  参数,如:`/comment/like?type=6&cid=1419532712&threadId=A_EV_2_6559519868_32953014&t=0``threadId` 可通过 `/event``/user/event` 接口获取

B
binaryify 已提交
1123 1124 1125 1126 1127 1128 1129 1130
### 发送/删除评论

说明 : 调用此接口,可发送评论或者删除评论

**接口地址 :** `/comment`

1. 发送评论

B
binaryify 已提交
1131
   **必选参数**
1132

B
v3.0.0  
binaryify 已提交
1133
   `t`:1 发送
B
binaryify 已提交
1134

1135
   `tpye`: 数字,资源类型,对应歌曲,mv,专辑,歌单,电台,视频对应以下类型
B
binaryify 已提交
1136 1137 1138

   ```
   0: 歌曲
1139

B
binaryify 已提交
1140
   1: mv
1141

B
binaryify 已提交
1142
   2: 歌单
1143

B
binaryify 已提交
1144
   3: 专辑
1145

B
binaryify 已提交
1146
   4: 电台
1147

1148
   5: 视频
1149 1150

   6: 动态
B
binaryify 已提交
1151 1152 1153 1154 1155 1156
   ```

   `id`:对应资源 id

   `content` :要发送的内容

B
v3.0.0  
binaryify 已提交
1157
   **调用例子** : `/comment?t=1&type=1&id=5436712&content=test` (往广岛之恋 mv 发送评论: test)
B
binaryify 已提交
1158

1159 1160
   注意:如给动态发送评论,则不需要传 id,需要传动态的 `threadId`,如:`/comment?t=1&type=6&threadId=A_EV_2_6559519868_32953014&content=test`

B
binaryify 已提交
1161
2. 删除评论
B
binaryify 已提交
1162 1163

   **必选参数**
1164

B
v3.0.0  
binaryify 已提交
1165
   `t`:0 删除
B
binaryify 已提交
1166

B
binaryify 已提交
1167 1168
   `tpye`: 数字,资源类型,对应歌曲,mv,专辑,歌单,电台,视频对应以下类型  
   
B
binaryify 已提交
1169 1170 1171

   ```
   0: 歌曲
1172

B
binaryify 已提交
1173
   1: mv
1174

B
binaryify 已提交
1175
   2: 歌单
1176

B
binaryify 已提交
1177
   3: 专辑
1178

B
binaryify 已提交
1179
   4: 电台
1180 1181


1182
   5: 视频
1183 1184 1185

   6: 动态
   
B
binaryify 已提交
1186 1187 1188 1189
   ```

   `id`:对应资源 id
   `content` :内容 id,可通过 `/comment/mv` 等接口获取
B
binaryify 已提交
1190

B
v3.0.0  
binaryify 已提交
1191
   **调用例子** : `/comment?t=0&type=1&id=5436712&commentId=1535550516319` (在广岛之恋 mv 删除评论)
1192 1193 1194
    

    注意:如给动态删除评论,则不需要传 id,需要传动态的 `threadId`,如:`/comment?t=0&type=6&threadId=A_EV_2_6559519868_32953014&commentId=1419516382`
B
binaryify 已提交
1195

B
binaryify 已提交
1196

1197 1198
### banner

B
binaryify 已提交
1199
说明 : 调用此接口 , 可获取 banner( 轮播图 ) 数据
1200

1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214
**可选参数 :**

`type`:资源类型,对应以下类型,默认为 0 即PC

```
0: pc

1: android

2: iphone

3: ipad
```

B
improve  
binaryify 已提交
1215 1216
**接口地址 :** `/banner`

1217
**调用例子 :** `/banner`, `/banner?type=2`
B
binaryify 已提交
1218

B
v3.0.0  
binaryify 已提交
1219 1220
### 资源点赞( MV,电台,视频)

B
binaryify 已提交
1221
说明 : 调用此接口 , 可对 MV,电台,视频点赞
B
v3.0.0  
binaryify 已提交
1222

B
binaryify 已提交
1223
**必选参数 :**
B
v3.0.0  
binaryify 已提交
1224 1225

`type`:资源类型,对应以下类型
B
binaryify 已提交
1226

B
v3.0.0  
binaryify 已提交
1227 1228
```
1: mv
1229

B
v3.0.0  
binaryify 已提交
1230
4: 电台
1231

B
v3.0.0  
binaryify 已提交
1232
5: 视频
1233 1234

6: 动态
B
v3.0.0  
binaryify 已提交
1235 1236
```

B
binaryify 已提交
1237
`t`: 操作,1 为点赞,其他未取消点赞
B
v3.0.0  
binaryify 已提交
1238

B
binaryify 已提交
1239
`id`: 资源 id
B
v3.0.0  
binaryify 已提交
1240 1241 1242 1243 1244

**接口地址 :** `/resource/like`

**调用例子 :** `/resource/like?t=1&type=1&id=5436712`

1245 1246 1247
注意:如给动态点赞,不需要传入 id,需要传入 `threadId`,可通过 `event`,`/user/event` 接口获取,如:
`/resource/like?t=1&type=6&threadId=A_EV_2_6559519868_32953014`

B
binaryify 已提交
1248 1249
### 获取歌曲详情

B
v3.0.0  
binaryify 已提交
1250
说明 : 调用此接口 , 传入音乐 id(支持多个 id, 用 `,` 隔开), 可获得歌曲详情(注意:歌曲封面现在需要通过专辑内容接口获取)
B
binaryify 已提交
1251

B
improve  
binaryify 已提交
1252
**必选参数 :** `ids`: 音乐 id, 如 `ids=347230`
B
binaryify 已提交
1253

B
improve  
binaryify 已提交
1254
**接口地址 :** `/song/detail`
B
binaryify 已提交
1255

B
v3.0.0  
binaryify 已提交
1256
**调用例子 :** `/song/detail?ids=347230`,`/song/detail?ids=347230,347231`
B
binaryify 已提交
1257

B
improve  
binaryify 已提交
1258 1259
返回数据如下图 :
![获取歌曲详情](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/songDetail.png)
B
binaryify 已提交
1260

B
binaryify 已提交
1261
### 获取专辑内容
1262

B
improve  
binaryify 已提交
1263
说明 : 调用此接口 , 传入专辑 id, 可获得专辑内容
1264

B
improve  
binaryify 已提交
1265
**必选参数 :** `id`: 专辑 id
1266

B
improve  
binaryify 已提交
1267
**接口地址 :** `/album`
1268

B
improve  
binaryify 已提交
1269 1270 1271
**调用例子 :** `/album?id=32311`

返回数据如下图 :
1272
![获取专辑内容](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E4%B8%93%E8%BE%91.png)
1273

1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286
### 获取已收藏专辑列表
说明 : 调用此接口 , 可获得已收藏专辑列表

**可选参数 :**  
`limit`: 取出数量 , 默认为 25

`offset`: 偏移数量 , 用于分页 , 如 :( 页数 -1)\*25, 其中 25 为 limit 的值 , 默认
为 0

**接口地址 :** `/album/sublist`

**调用例子 :** `/album/sublist` ( 周杰伦 )

1287
### 获取歌手单曲
1288

B
improve  
binaryify 已提交
1289
说明 : 调用此接口 , 传入歌手 id, 可获得歌手部分信息和热门歌曲
B
improve  
binaryify 已提交
1290 1291

**必选参数 :** `id`: 歌手 id, 可由搜索接口获得
1292

B
improve  
binaryify 已提交
1293
**接口地址 :** `/artists`
1294

B
improve  
binaryify 已提交
1295
**调用例子 :** `/artists?id=6452`
1296

B
improve  
binaryify 已提交
1297
返回数据如下图 :
1298 1299
![获取歌手单曲](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/artists.png)

1300
### 获取歌手 mv
B
improve  
binaryify 已提交
1301 1302 1303

说明 : 调用此接口 , 传入歌手 id, 可获得歌手 mv 信息 , 具体 mv 播放地址可调
`/mv`传入此接口获得的 mvid 来拿到 , 如 :
1304 1305
`/artist/mv?id=6452`,`/mv?mvid=5461064`

B
improve  
binaryify 已提交
1306
**必选参数 :** `id`: 歌手 id, 可由搜索接口获得
1307

B
improve  
binaryify 已提交
1308
**接口地址 :** `/artist/mv`
1309

B
improve  
binaryify 已提交
1310
**调用例子 :** `/artist/mv?id=6452`
1311

1312
### 获取歌手专辑
1313

B
improve  
binaryify 已提交
1314
说明 : 调用此接口 , 传入歌手 id, 可获得歌手专辑内容
1315

B
improve  
binaryify 已提交
1316
**必选参数 :** `id`: 歌手 id
1317

B
improve  
binaryify 已提交
1318
**可选参数 :** `limit`: 取出数量 , 默认为 50
B
binaryify 已提交
1319

B
improve  
binaryify 已提交
1320 1321
`offset`: 偏移数量 , 用于分页 , 如 :( 页数 -1)\*50, 其中 50 为 limit 的值 , 默认
为 0
1322

B
improve  
binaryify 已提交
1323
**接口地址 :** `/artist/album`
1324

B
improve  
binaryify 已提交
1325 1326 1327
**调用例子 :** `/artist/album?id=6452&limit=30` ( 周杰伦 )

返回数据如下图 :
1328
![获取专辑内容](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/artist_album.png)
1329

1330 1331
### 获取歌手描述

B
improve  
binaryify 已提交
1332 1333 1334
说明 : 调用此接口 , 传入歌手 id, 可获得歌手描述

**必选参数 :** `id`: 歌手 id
1335

B
improve  
binaryify 已提交
1336
**接口地址 :** `/artist/desc`
1337

B
improve  
binaryify 已提交
1338
**调用例子 :** `/artist/desc?id=6452` ( 周杰伦 )
1339 1340 1341

### 获取相似歌手

B
improve  
binaryify 已提交
1342 1343 1344
说明 : 调用此接口 , 传入歌手 id, 可获得相似歌手

**必选参数 :** `id`: 歌手 id
1345

B
improve  
binaryify 已提交
1346
**接口地址 :** `/simi/artist`
1347

B
improve  
binaryify 已提交
1348
**调用例子 :** `/simi/artist?id=6452` ( 对应和周杰伦相似歌手 )
1349 1350 1351

### 获取相似歌单

B
improve  
binaryify 已提交
1352
说明 : 调用此接口 , 传入歌曲 id, 可获得相似歌单
1353

B
improve  
binaryify 已提交
1354
**必选参数 :** `id`: 歌曲 id
1355

B
improve  
binaryify 已提交
1356
**接口地址 :** `/simi/playlist`
1357

B
improve  
binaryify 已提交
1358
**调用例子 :** `/simi/playlist?id=347230` ( 对应 ' 光辉岁月 ' 相似歌单 )
1359 1360 1361

### 相似 mv

B
binaryify 已提交
1362 1363 1364
说明 : 调用此接口 , 传入 `mvid` 可获取相似 mv

**必选参数 :** `mvid`: mv id
1365

B
improve  
binaryify 已提交
1366
**接口地址 :** `/simi/mv`
1367

B
improve  
binaryify 已提交
1368
**调用例子 :** `/simi/mv?mvid=5436712`
1369 1370 1371

### 获取相似音乐

B
improve  
binaryify 已提交
1372
说明 : 调用此接口 , 传入歌曲 id, 可获得相似歌曲
1373

B
improve  
binaryify 已提交
1374
**必选参数 :** `id`: 歌曲 id
1375

B
improve  
binaryify 已提交
1376
**接口地址 :** `/simi/song`
1377

B
improve  
binaryify 已提交
1378
**调用例子 :** `/simi/song?id=347230` ( 对应 ' 光辉岁月 ' 相似歌曲 )
1379

B
improve  
binaryify 已提交
1380
### 获取最近 5 个听了这首歌的用户
1381

B
improve  
binaryify 已提交
1382
说明 : 调用此接口 , 传入歌曲 id, 最近 5 个听了这首歌的用户
1383

B
improve  
binaryify 已提交
1384
**必选参数 :** `id`: 歌曲 id
1385

B
improve  
binaryify 已提交
1386 1387 1388
**接口地址 :** `/simi/user`

**调用例子 :** `/simi/user?id=347230` ( 对应 ' 光辉岁月 ' 相似歌曲 )
1389

B
binaryify 已提交
1390
### 获取每日推荐歌单
1391

B
improve  
binaryify 已提交
1392 1393 1394
说明 : 调用此接口 , 可获得每日推荐歌单 ( 需要登录 )

**接口地址 :** `/recommend/resource`
1395

B
improve  
binaryify 已提交
1396
**调用例子 :** `/recommend/resource`
1397

B
improve  
binaryify 已提交
1398
返回数据如下图 :
1399
![每日推荐歌单](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E6%8E%A8%E8%8D%90%E6%AD%8C%E5%8D%95.png)
1400

B
binaryify 已提交
1401
### 获取每日推荐歌曲
1402

B
improve  
binaryify 已提交
1403
说明 : 调用此接口 , 可获得每日推荐歌曲 ( 需要登录 )
1404

B
improve  
binaryify 已提交
1405
**接口地址 :** `/recommend/songs`
1406

B
improve  
binaryify 已提交
1407
**调用例子 :** `/recommend/songs`
B
binaryify 已提交
1408

B
improve  
binaryify 已提交
1409 1410
返回数据如下图 :
![每日推荐歌曲](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/%E6%8E%A8%E8%8D%90%E6%AD%8C%E6%9B%B2.png)
1411 1412 1413

### 私人 FM

B
improve  
binaryify 已提交
1414 1415 1416
说明 : 私人 FM( 需要登录 )

**接口地址 :** `/personal_fm`
1417

B
improve  
binaryify 已提交
1418
**调用例子 :** `/personal_fm`
1419

B
improve  
binaryify 已提交
1420
返回数据如下图 :
1421 1422 1423 1424 1425

![私人 FM](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/personal_fm.png)

### 签到

B
improve  
binaryify 已提交
1426 1427 1428
说明 : 调用此接口 , 传入签到类型 ( 可不传 , 默认安卓端签到 ), 可签到 ( 需要登录
), 其中安卓端签到可获得 3 点经验 , web/PC 端签到可获得 2 点经验

B
improve  
binaryify 已提交
1429
**可选参数 :** `type`: 签到类型 , 默认 0, 其中 0 为安卓端签到 ,1 为 web/PC 签到
1430

B
improve  
binaryify 已提交
1431
**接口地址 :** `/daily_signin`
1432

B
improve  
binaryify 已提交
1433 1434 1435
**调用例子 :** `/daily_signin`

返回数据如下图 :
1436

B
binaryify 已提交
1437
![签到成功](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/signinSuccess.png)
1438 1439 1440 1441

![签到失败](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/signinError.png)

### 喜欢音乐
B
binaryify 已提交
1442

B
improve  
binaryify 已提交
1443 1444 1445
说明 : 调用此接口 , 传入音乐 id, 可喜欢该音乐

**必选参数 :** `id`: 歌曲 id
1446

B
improve  
binaryify 已提交
1447
**可选参数 :** `like`: 布尔值 , 默认为 true 即喜欢 , 若传 false, 则取消喜欢
1448

B
improve  
binaryify 已提交
1449
**接口地址 :** `/like`
1450

B
improve  
binaryify 已提交
1451
**调用例子 :** `/like?id=347230`
1452

B
improve  
binaryify 已提交
1453
返回数据如下图 :
1454 1455 1456

![喜欢成功](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/like.png)

B
improve  
binaryify 已提交
1457
喜欢成功则返回数据的 code 为 200, 其余为失败
B
binaryify 已提交
1458

1459 1460
![喜欢成功截图](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/likeSuccess.png)

1461 1462 1463 1464 1465 1466 1467 1468 1469 1470
### 喜欢音乐列表

说明 : 调用此接口 , 传入用户 id, 可获取已喜欢音乐id列表(id数组)

**必选参数 :** `uid`: 用户 id

**接口地址 :** `/likelist`

**调用例子 :** `/likelist?uid=32953014`

1471 1472
### 垃圾桶

B
improve  
binaryify 已提交
1473 1474 1475
说明 : 调用此接口 , 传入音乐 id, 可把该音乐从私人 FM 中移除至垃圾桶

**必选参数 :** `id`: 歌曲 id
1476

B
improve  
binaryify 已提交
1477
**接口地址 :** `/fm_trash`
1478

B
improve  
binaryify 已提交
1479
**调用例子 :** `/fm_trash?id=347230`
1480

B
improve  
binaryify 已提交
1481
返回数据如下图 :
1482 1483 1484

![移除成功](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/fm_trash.png)

1485
### 新碟上架
N
nujhong 已提交
1486

B
improve  
binaryify 已提交
1487 1488 1489 1490
说明 : 调用此接口 , 可获取新碟上架列表 , 如需具体音乐信息需要调用获取专辑列表接
`/album` , 然后传入 id, 如 `/album?id=32311&limit=30`

**可选参数 :** `limit`: 取出数量 , 默认为 50
1491

B
improve  
binaryify 已提交
1492 1493
`offset`: 偏移数量 , 用于分页 , 如 :( 页数 -1)\*50, 其中 50 为 limit 的值 , 默认
为 0
1494

B
improve  
binaryify 已提交
1495
**接口地址 :** `/top/album`
1496

B
improve  
binaryify 已提交
1497
**调用例子 :** `/top/album?offset=0&limit=30`
1498

B
improve  
binaryify 已提交
1499
返回数据如下图 :
1500 1501 1502

![新碟上架](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/new_albums.png)

T
trazyn 已提交
1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522
### 最新专辑

说明 : 调用此接口 ,获取云音乐首页新碟上架数据

**接口地址 :** `/album/newest`

**调用例子 :** `/likelist?uid=32953014`

### 听歌打卡

说明 : 调用此接口 , 传入音乐 id, 来源 id,歌曲时间 time,更新听歌排行数据

**必选参数 :** `id`: 歌曲 id, `sourceid`: 歌单或专辑 id

**可选参数 :** `time`: 歌曲播放时间

**接口地址 :** `/scrobble`

**调用例子 :** `/scrobble?id=482369360&&sourceid=35571977`

1523
### 热门歌手
N
nujhong 已提交
1524

B
improve  
binaryify 已提交
1525 1526 1527
说明 : 调用此接口 , 可获取热门歌手数据

**可选参数 :** `limit`: 取出数量 , 默认为 50
1528

B
improve  
binaryify 已提交
1529 1530
`offset`: 偏移数量 , 用于分页 , 如 :( 页数 -1)\*50, 其中 50 为 limit 的值 , 默认
为 0
1531

B
improve  
binaryify 已提交
1532
**接口地址 :** `/top/artists`
1533

B
improve  
binaryify 已提交
1534
**调用例子 :** `/top/artists?offset=0&limit=30`
1535

B
improve  
binaryify 已提交
1536
返回数据如下图 :
1537 1538 1539

![热门歌手](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/top_artists.png)

1540
### 最新 mv
N
nujhong 已提交
1541

B
improve  
binaryify 已提交
1542
说明 : 调用此接口 , 可获取最新 mv
1543

B
improve  
binaryify 已提交
1544
**可选参数 :** `limit`: 取出数量 , 默认为 30
1545

B
improve  
binaryify 已提交
1546 1547 1548
**接口地址 :** `/mv/first`

**调用例子 :** `/mv/first?limit=10`
1549 1550

### 推荐 mv
N
nujhong 已提交
1551

B
improve  
binaryify 已提交
1552 1553 1554
说明 : 调用此接口 , 可获取推荐 mv

**接口地址 :** `/personalized/mv`
1555

B
improve  
binaryify 已提交
1556
**调用例子 :** `/personalized/mv`
1557 1558

### 推荐歌单
N
nujhong 已提交
1559

B
improve  
binaryify 已提交
1560 1561 1562
说明 : 调用此接口 , 可获取推荐歌单

**接口地址 :** `/personalized`
1563

B
improve  
binaryify 已提交
1564
**调用例子 :** `/personalized`
1565 1566

### 推荐新音乐
N
nujhong 已提交
1567

B
improve  
binaryify 已提交
1568
说明 : 调用此接口 , 可获取推荐新音乐
1569

B
improve  
binaryify 已提交
1570 1571 1572
**接口地址 :** `/personalized/newsong`

**调用例子 :** `/personalized/newsong`
1573 1574

### 推荐电台
N
nujhong 已提交
1575

B
improve  
binaryify 已提交
1576 1577 1578
说明 : 调用此接口 , 可获取推荐电台

**接口地址 :** `/personalized/djprogram`
1579

B
improve  
binaryify 已提交
1580
**调用例子 :** `/personalized/djprogram`
1581 1582

### 推荐节目
N
nujhong 已提交
1583

B
improve  
binaryify 已提交
1584 1585 1586
说明 : 调用此接口 , 可获取推荐电台

**接口地址 :** `/program/recommend`
1587

B
improve  
binaryify 已提交
1588
**调用例子 :** `/program/recommend`
1589 1590

### 独家放送
N
nujhong 已提交
1591

B
improve  
binaryify 已提交
1592
说明 : 调用此接口 , 可获取独家放送
1593

B
improve  
binaryify 已提交
1594
**接口地址 :** `/personalized/privatecontent`
1595

B
improve  
binaryify 已提交
1596
**调用例子 :** `/personalized/privatecontent`
1597 1598

### mv 排行
N
nujhong 已提交
1599

B
improve  
binaryify 已提交
1600
说明 : 调用此接口 , 可获取 mv 排行
1601

B
improve  
binaryify 已提交
1602
**可选参数 :** `limit`: 取出数量 , 默认为 30
1603

B
improve  
binaryify 已提交
1604 1605
`offset`: 偏移数量 , 用于分页 , 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认
为 0
1606

B
improve  
binaryify 已提交
1607 1608 1609
**接口地址 :** `top/mv`

**调用例子 :** `top/mv?limit=10`
1610 1611

### 获取 mv 数据
N
nujhong 已提交
1612

B
improve  
binaryify 已提交
1613 1614
说明 : 调用此接口 , 传入 mvid ( 在搜索音乐的时候传 type=1004 获得 ) , 可获取对应
MV 数据 , 数据包含 mv 名字 , 歌手 , 发布时间 , mv 视频地址等数据 , 其中 mv 视频
B
v3.0.0  
binaryify 已提交
1615
网易做了防盗链处理 , 可能不能直接播放 , 需要播放的话需要调用 ' mv 地址' 接口
B
binaryify 已提交
1616

B
improve  
binaryify 已提交
1617
**必选参数 :** `mvid`: mv 的 id
B
binaryify 已提交
1618

B
v3.0.0  
binaryify 已提交
1619
**接口地址 :** `/mv/detail`
B
binaryify 已提交
1620

B
v3.0.0  
binaryify 已提交
1621
**调用例子 :** `/mv/detail?mvid=5436712`
B
binaryify 已提交
1622

B
improve  
binaryify 已提交
1623
返回数据如下图 :
B
binaryify 已提交
1624

B
improve  
binaryify 已提交
1625
![热门歌手](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/mv.png)
B
binaryify 已提交
1626

B
v3.0.0  
binaryify 已提交
1627
### mv 地址
1628

B
v3.0.0  
binaryify 已提交
1629 1630 1631 1632 1633 1634 1635
说明 : 调用此接口 , 传入 mv id,可获取 mv 播放地址

**可选参数 :** `url`: mv id

**接口地址 :** `/mv/url`

**调用例子 :**
1636

B
v3.0.0  
binaryify 已提交
1637 1638 1639
`/mv/url?id=5436712`

### 相关视频
B
binaryify 已提交
1640

B
v3.0.0  
binaryify 已提交
1641
说明 : 调用此接口 , 可获取相关视频
1642

B
binaryify 已提交
1643
**必选参数 :** `id`: 视频 的 id
1644

B
v3.0.0  
binaryify 已提交
1645
**接口地址 :** `/related/allvideo`
1646

B
v3.0.0  
binaryify 已提交
1647
**调用例子 :** `/related/allvideo?id=89ADDE33C0AAE8EC14B99F6750DB954D`
1648

B
v3.0.0  
binaryify 已提交
1649
### 视频详情
B
binaryify 已提交
1650

B
v3.0.0  
binaryify 已提交
1651
说明 : 调用此接口 , 可获取相关视频
1652

B
v3.0.0  
binaryify 已提交
1653
**必选参数 :** `id`: 视频 的 id
1654

B
v3.0.0  
binaryify 已提交
1655
**接口地址 :** `/video/detail`
N
nujhong 已提交
1656

B
v3.0.0  
binaryify 已提交
1657
**调用例子 :** `/video/detail?id=89ADDE33C0AAE8EC14B99F6750DB954D`
B
binaryify 已提交
1658

B
v3.0.0  
binaryify 已提交
1659
### 获取视频数据
B
binaryify 已提交
1660

B
binaryify 已提交
1661
说明 : 调用此接口 , 传入视频 id,可获取视频播放地址
B
improve  
binaryify 已提交
1662

B
v3.0.0  
binaryify 已提交
1663 1664 1665 1666 1667 1668 1669
**必选参数 :** `id`: 视频 的 id

**接口地址 :** `/video/url`

**调用例子 :** `/video/url?id=89ADDE33C0AAE8EC14B99F6750DB954D`

返回数据如下图 :
B
binaryify 已提交
1670

B
v3.0.0  
binaryify 已提交
1671
![视频数据](https://ws1.sinaimg.cn/large/006tNbRwgy1fuqdv10p5rj31kw0da76y.jpg)
B
binaryify 已提交
1672

1673 1674 1675 1676 1677 1678 1679 1680 1681 1682 1683

### 获取视频标签下的视频
说明 : 调用此接口 , 传入`videoGroupId`,可获取到相关的视频。  

**必选参数 :** `传入videoGroupId`: videoGroup 的 id

**接口地址 :** `/video/group`

**调用例子 :** `/video/group?id=9104`


B
binaryify 已提交
1684
### 排行榜
1685

B
improve  
binaryify 已提交
1686 1687 1688
说明 : 调用此接口 , 传入数字 idx, 可获取不同排行榜

**必选参数 :** `idx`: 对象 key, 对应以下排行榜
B
binaryify 已提交
1689 1690

```
B
improve  
binaryify 已提交
1691
"0": 云音乐新歌榜,
1692

B
improve  
binaryify 已提交
1693
"1": 云音乐热歌榜,
1694

B
improve  
binaryify 已提交
1695
"2": 网易原创歌曲榜,
1696

B
improve  
binaryify 已提交
1697
"3": 云音乐飙升榜,
1698

B
improve  
binaryify 已提交
1699
"4": 云音乐电音榜,
1700

B
improve  
binaryify 已提交
1701
"5": UK排行榜周榜,
1702

B
improve  
binaryify 已提交
1703
"6": 美国Billboard周榜
1704

B
improve  
binaryify 已提交
1705
"7": KTV嗨榜,
1706

B
improve  
binaryify 已提交
1707
"8": iTunes榜,
1708

B
improve  
binaryify 已提交
1709
"9": Hit FM Top榜,
1710

B
improve  
binaryify 已提交
1711
"10": 日本Oricon周榜
1712

B
improve  
binaryify 已提交
1713
"11": 韩国Melon排行榜周榜,
1714

B
improve  
binaryify 已提交
1715
"12": 韩国Mnet排行榜周榜,
1716

B
improve  
binaryify 已提交
1717
"13": 韩国Melon原声周榜,
1718

B
improve  
binaryify 已提交
1719
"14": 中国TOP排行榜(港台榜),
1720

B
improve  
binaryify 已提交
1721
"15": 中国TOP排行榜(内地榜)
1722

B
improve  
binaryify 已提交
1723
"16": 香港电台中文歌曲龙虎榜,
1724

B
improve  
binaryify 已提交
1725
"17": 华语金曲榜,
1726

B
improve  
binaryify 已提交
1727
"18": 中国嘻哈榜,
1728

B
improve  
binaryify 已提交
1729
"19": 法国 NRJ EuroHot 30周榜,
1730

B
improve  
binaryify 已提交
1731
"20": 台湾Hito排行榜,
1732

N
nujhong 已提交
1733
"21": Beatport全球电子舞曲榜,
1734

N
nujhong 已提交
1735
"22": 云音乐ACG音乐榜,
1736

N
nujhong 已提交
1737 1738
"23": 云音乐嘻哈榜
```
B
binaryify 已提交
1739

B
improve  
binaryify 已提交
1740
**接口地址 :** `/top/list`
B
binaryify 已提交
1741

B
improve  
binaryify 已提交
1742
**调用例子 :** `/top/list?idx=6`
B
binaryify 已提交
1743

B
improve  
binaryify 已提交
1744
返回数据如下图 :
B
binaryify 已提交
1745 1746

![排行榜](https://raw.githubusercontent.com/Binaryify/NeteaseCloudMusicApi/master/static/top_list.png)
1747

1748 1749 1750 1751 1752 1753 1754
### 所有榜单

说明 : 调用此接口,可获取所有榜单
**接口地址 :** `/toplist`

**调用例子 :** `/toplist`

B
v3.0.0  
binaryify 已提交
1755
### 所有榜单内容摘要
B
binaryify 已提交
1756

B
v3.0.0  
binaryify 已提交
1757 1758 1759 1760 1761
说明 : 调用此接口,可获取所有榜单内容摘要
**接口地址 :** `/toplist/detail`

**调用例子 :** `/toplist/detail`

H
hzw758 已提交
1762 1763
### 歌手榜

B
v3.0.0  
binaryify 已提交
1764
说明 : 调用此接口 , 可获取排行榜中的歌手榜
H
hzw758 已提交
1765

B
improve  
binaryify 已提交
1766 1767 1768
**接口地址 :** `/toplist/artist`

**调用例子 :** `/toplist/artist`
1769 1770 1771

### 云盘

B
improve  
binaryify 已提交
1772
说明 : 登陆后调用此接口 , 可获取云盘数据 , 获取的数据没有对应 url, 需要再调用一
B
v3.0.0  
binaryify 已提交
1773
`/song/url` 获取 url
B
improve  
binaryify 已提交
1774 1775 1776 1777

**接口地址 :** `/user/cloud`

**调用例子 :** `/user/cloud`
1778

B
binaryify 已提交
1779 1780 1781 1782 1783 1784 1785 1786 1787 1788
### 云盘数据详情
说明 : 登陆后调用此接口 , 传入云盘歌曲 id,可获取云盘数据详情

**必选参数 :** `id`: 歌曲id,可多个,用逗号隔开

**接口地址 :** `/user/cloud/detail`

**调用例子 :** `/user/cloud/detail?id=5374627`


1789 1790 1791 1792 1793 1794 1795 1796 1797
### 云盘歌曲删除
说明 : 登陆后调用此接口 , 可删除云盘歌曲

**必选参数 :** `id`: 歌曲id,可多个,用逗号隔开

**接口地址 :** `/user/cloud/del`

**调用例子 :** `/user/cloud/del`

B
improve  
binaryify 已提交
1798
### 电台 - 推荐
1799

B
improve  
binaryify 已提交
1800
说明 : 登陆后调用此接口 , 可获得推荐电台
1801

B
improve  
binaryify 已提交
1802
**接口地址 :** `/dj/recommend`
1803

B
improve  
binaryify 已提交
1804
**调用例子 :** `/dj/recommend`
1805

B
improve  
binaryify 已提交
1806
### 电台 - 分类
1807

B
improve  
binaryify 已提交
1808
说明 : 登陆后调用此接口 , 可获得电台类型
1809

B
improve  
binaryify 已提交
1810
**接口地址 :** `/dj/catelist`
1811

B
improve  
binaryify 已提交
1812
**调用例子 :** `/dj/catelist`
1813

B
improve  
binaryify 已提交
1814
### 电台 - 分类推荐
1815

B
improve  
binaryify 已提交
1816
说明 : 登陆后调用此接口 , 可获得推荐电台
1817

B
improve  
binaryify 已提交
1818 1819
**必选参数 :** `type`: 电台类型 , 数字 , 可通过`/dj/catelist`获取 , 对应关系为
id 对应 此接口的 type, name 对应类型意义
1820

B
improve  
binaryify 已提交
1821
**接口地址 :** `/dj/recommend/type`
1822

B
improve  
binaryify 已提交
1823
**调用例子 :** `/dj/recommend/type?type=1`
1824

B
improve  
binaryify 已提交
1825
### 电台 - 订阅
1826

B
improve  
binaryify 已提交
1827 1828
说明 : 登陆后调用此接口 , 传入`rid`, 可订阅 dj,dj 的 `rid` 可通过搜索指定
type='1009' 获取其 id, 如`/search?keywords= 代码时间 &type=1009`
1829

B
improve  
binaryify 已提交
1830
**必选参数 :** `rid`: 电台 的 id
1831

B
improve  
binaryify 已提交
1832
**接口地址 :** `/dj/sub`
1833

B
improve  
binaryify 已提交
1834 1835
**调用例子 :** `/dj/sub?rid=336355127&t=1` ( 对应关注 ' 代码时间 ')
`/dj/sub?rid=336355127&t=0` ( 对应取消关注 ' 代码时间 ')
1836

1837 1838 1839 1840 1841 1842 1843 1844
### 电台的订阅列表

说明 : 登陆后调用此接口 , 可获取订阅的电台列表

**接口地址 :** `/dj/sublist`

**调用例子 :** `/dj/sublist`

add doc  
徐星宇 已提交
1845 1846 1847 1848
### 电台 - 付费精选

说明 : 可以获取付费精选的电台列表 , 传入 `limit``offset` 可以进行分页

1849 1850 1851 1852 1853 1854
**可选参数 :**

`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 ,  如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0

add doc  
徐星宇 已提交
1855 1856 1857 1858
**接口地址 :** `/dj/paygift`

**调用例子 :** `/dj/paygift?limit=10&offset=20`

1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885
### 电台 - 非热门类型

说明 : 登陆后调用此接口, 可获得电台非热门类型


**接口地址 :** `/dj/category/excludehot`

**调用例子 :** `/dj/category/excludehot`

### 电台 - 推荐类型

说明 : 登陆后调用此接口, 可获得电台推荐类型


**接口地址 :** `/dj/category/recommend`

**调用例子 :** `/dj/category/recommend`

### 电台 - 今日优选

说明 : 登陆后调用此接口, 可获得电台今日优选


**接口地址 :** `/dj/today/perfered`

**调用例子 :** `/dj/today/perfered`

B
improve  
binaryify 已提交
1886
### 电台 - 详情
1887

B
improve  
binaryify 已提交
1888
说明 : 登陆后调用此接口 , 传入`rid`, 可获得对应电台的详情介绍
1889

B
improve  
binaryify 已提交
1890
**必选参数 :** `rid`: 电台 的 id
1891

B
improve  
binaryify 已提交
1892
**接口地址 :** `/dj/detail?rid=336355127`
1893

B
improve  
binaryify 已提交
1894
**调用例子 :** `/dj/detail?rid=336355127` ( 对应 ' 代码时间 ' 的详情介绍 )
1895

B
improve  
binaryify 已提交
1896
### 电台 - 节目
1897

B
improve  
binaryify 已提交
1898
说明 : 登陆后调用此接口 , 传入`rid`, 可查看对应电台的电台节目以及对应的 id, 需要
B
v3.0.0  
binaryify 已提交
1899 1900
注意的是这个接口返回的 mp3Url 已经无效 , 都为 null, 但是通过调用 `/song/url`
个接口 , 传入节目 id 仍然能获取到节目音频 , 如 `/song/url?id=478446370` 获取代
B
improve  
binaryify 已提交
1901 1902 1903 1904
码时间的一个节目的音频

**必选参数 :** `rid`: 电台 的 id

B
binaryify 已提交
1905
**可选参数 :**
1906

B
binaryify 已提交
1907 1908
`limit` : 返回数量 , 默认为 30

1909
`offset` : 偏移数量,用于分页 , 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0
B
binaryify 已提交
1910

1911 1912
`asc` : 排序方式,默认为 `false` (新 => 老 ) 设置 `true` 可改为 老 => 新 

B
improve  
binaryify 已提交
1913 1914
**接口地址 :** `/dj/program`

B
binaryify 已提交
1915
**调用例子 :** `/dj/program?rid=336355127&limit=40` ( 对应 ' 代码时间 ' 的节目列表 )
1916

B
binaryify 已提交
1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931

### 通知 - 私信

说明 : 登陆后调用此接口 ,可获取私信

**可选参数 :**

`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 , 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0

**接口地址 :** `/msg/private`

**调用例子 :** `/msg/private?limit=3`

B
v3.12.0  
binaryify 已提交
1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981
### 发送私信

说明 : 登陆后调用此接口 , 传入用户 id 和要发送的信息, 可以发送私信,返回内容为历史私信,包含带歌单的私信信息(注:不能发送私信给自己)

**必选参数 :**

`user_ids` : 用户 id,多个需用逗号隔开

`msg` : 要发送的信息

**接口地址 :** `/send/text`

**调用例子 :** `/send/text?user_ids=32953014&msg=test`,`/send/text?user_ids=32953014,475625142&msg=test`
返回数据如下图:
![数据](https://ws1.sinaimg.cn/large/006tKfTcgy1fr3p3hfeudj31kw1aek2e.jpg)

### 私信内容
说明 : 登陆后调用此接口 , 可获取私信内容

**必选参数 :**
`uid` : 用户 id

**可选参数 :**
`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 , 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0

**接口地址 :** 
`/msg/private/history`

**调用例子 :**
`/msg/private/history?uid=9003` (云音乐小秘书)

### 发送私信(带歌单)

说明 : 登陆后调用此接口 , 传入用户 id 和要发送的信息和歌单 id, 可以发送带歌单的私信(注:不能发送重复的歌单)

**必选参数 :**

`user_ids` : 用户 id,多个需用逗号隔开

`msg` : 要发送的信息

**接口地址 :** `/send/playlist`

**调用例子 :** `/send/playlist?msg=test&user_ids=475625142&playlist=705123491`,`/send/playlist?msg=test2&user_ids=475625142,32953014&playlist=705123493`
返回数据如下图:
![数据](https://ws1.sinaimg.cn/large/006tKfTcgy1fr3p1z7qmcj30v409adg5.jpg)


B
binaryify 已提交
1982 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036

### 通知 - 评论

说明 : 登陆后调用此接口 ,可获取评论

**必选参数 :** `uid`: 用户 的 id,只能和登录账号的 id 一致

**可选参数 :**

`limit` : 返回数量 , 默认为 30

`before` : 分页参数,取上一页最后一个歌单的 `updateTime` 获取下一页数据


**接口地址 :** `/msg/comments`

**调用例子 :** `/msg/comments?uid=32953014`

### 通知 - @我

说明 : 登陆后调用此接口 ,可获取@我数据

**可选参数 :**

`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 , 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0

**接口地址 :** `/msg/forwards`

**调用例子 :** `/msg/forwards?limit=3`


### 通知 - 通知

说明 : 登陆后调用此接口 ,可获取通知

**可选参数 :**

`limit` : 返回数量 , 默认为 30

`offset` : 偏移数量,用于分页 , 如 :( 页数 -1)\*30, 其中 30 为 limit 的值 , 默认为 0


**接口地址 :** `/msg/notices`

**调用例子 :** `/msg/notices?limit=3`

### 设置
说明 : 登陆后调用此接口 ,可获取用户设置

**接口地址 :** `/setting`

**调用例子 :** `/setting`

B
v3.12.0  
binaryify 已提交
2037 2038 2039 2040 2041 2042 2043
### 我的数字专辑
说明 : 登陆后调用此接口 ,可获取我的数字专辑

**接口地址 :** `/digitalAlbum/purchased`

**调用例子 :** `/digitalAlbum/purchased?limit=10`

B
binaryify 已提交
2044
## 离线访问此文档
B
binaryify 已提交
2045

B
improve  
binaryify 已提交
2046
此文档同时也是 Progressive Web Apps(PWA), 加入了 serviceWorker, 可离线访问
B
binaryify 已提交
2047 2048

## 关于此文档
B
improve  
binaryify 已提交
2049 2050 2051 2052

此文档由 [docsify](https://github.com/QingWei-Li/docsify/) 生成 docsify 是一个动
态生成文档网站的工具。不同于 GitBook、Hexo 的地方是它不会生成将 .md 转成 .html
文件,所有转换工作都是在运行时进行。
B
binaryify 已提交
2053

B
binaryify 已提交
2054
## License
B
improve  
binaryify 已提交
2055

B
binaryify 已提交
2056
[The MIT License (MIT)](https://github.com/Binaryify/NeteaseCloudMusicApi/blob/master/LICENSE)