/NeteaseCloudMusicApi

网易云音乐 Node.js API service

Primary LanguageJavaScriptMIT LicenseMIT

网易云音乐 API

网易云音乐 Node.js API service

Version License devDependencies devDependencies

灵感来自

disoul/electron-cloud-music

darknessomi/musicbox

sqaiyan/netmusic-node

greats3an/pyncm

环境要求

需要 NodeJS 14+ 环境

安装

$ git clone git@github.com:Binaryify/NeteaseCloudMusicApi.git
$ cd NeteaseCloudMusicApi
$ npm install

或者

$ git clone https://github.com/Binaryify/NeteaseCloudMusicApi.git
$ cd NeteaseCloudMusicApi
$ npm install

运行

调用前务必阅读文档的调用前须知

$ node app.js

服务器启动默认端口为 3000,若不想使用 3000 端口,可使用以下命令: Mac/Linux

$ PORT=4000 node app.js

windows 下使用 git-bash 或者 cmder 等终端执行以下命令:

$ set PORT=4000 && node app.js

Vercel 部署

v4.0.8 加入了 Vercel 配置文件,可以直接在 Vercel 下部署了,不需要自己的服务器

操作方法

  1. fork 此项目
  2. 在 Vercel 官网点击 New Project
  3. 点击 Import Git Repository 并选择你 fork 的此项目并点击import
  4. 点击 PERSONAL ACCOUNTselect
  5. 直接点Continue
  6. PROJECT NAME自己填,FRAMEWORK PRESETOther 然后直接点 Deploy 接着等部署完成即可

腾讯云 serverless 部署

Vercel 在国内访问太慢,在此提供腾讯云 serverless 部署方法(注意:腾讯云 serverless 并不是免费的,前三个月有免费额度,之后收费)

操作方法

  1. fork 此项目
  2. 在腾讯云serverless应用管理页面( https://console.cloud.tencent.com/sls ),点击新建应用
  3. 顶部创建方式选择 Web 应用
  4. 选择 Express框架,点击底部下一步按钮
  5. 输入应用名,上传方式选择代码仓库,进行GitHub授权(如已授权可跳过这一步),代码仓库选择刚刚fork的项目
  6. 启动文件填入:
#!/bin/bash
export PORT=9000
/var/lang/node16/bin/node app.js
  1. 点击完成,等待部署完成,点击资源列表API网关 里的 URL,正常情况会打开文档地址,点击文档例子可查看接口调用效果

可以在Node.js调用

v3.31.0后支持Node.js调用,导入的方法为module内的文件名,返回内容包含statusbody,status为状态码,body为请求返回内容,参考module_example 文件夹下的 test.js

const { login_cellphone, user_cloud } = require('NeteaseCloudMusicApi')
async function main() {
  try {
    const result = await login_cellphone({
      phone: '手机号',
      password: '密码'
    })
    console.log(result)
    const result2 = await user_cloud({
      cookie: result.body.cookie // 凭证
    })
    console.log(result2.body)
      
  } catch (error) {
    console.log(error)
  }
}
main()

支持 TypeScript

// test.ts
import { banner } from 'NeteaseCloudMusicApi'
banner({ type:0 }).then(res=>{
  console.log(res)
})

使用文档

文档地址

文档

功能特性

  1. 登录
  2. 刷新登录
  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. 歌单收藏者列表
  99. 云盘歌曲删除
  100. 热门话题
  101. 电台 - 推荐类型
  102. 电台 - 非热门类型
  103. 电台 - 今日优选
  104. 心动模式/智能播放
  105. 转发动态
  106. 删除动态
  107. 分享歌曲、歌单、mv、电台、电台节目到动态
  108. 通知-私信
  109. 通知-评论
  110. 通知-@我
  111. 通知-通知
  112. 设置
  113. 云盘数据详情
  114. 私信内容
  115. 我的数字专辑
  116. batch批量请求接口
  117. 获取视频标签列表
  118. 全部mv
  119. 网易出品mv
  120. 收藏/取消收藏专辑
  121. 专辑动态信息
  122. 热搜列表(详细)
  123. 更换绑定手机
  124. 检测手机号码是否已注册
  125. 初始化昵称
  126. 更新歌单描述
  127. 更新歌单名
  128. 更新歌单标签
  129. 默认搜索关键词
  130. 删除歌单
  131. 电台banner
  132. 用户电台
  133. 热门电台
  134. 电台 - 节目详情
  135. 电台 - 节目榜
  136. 电台 - 新晋电台榜/热门电台榜
  137. 类别热门电台
  138. 云村热评
  139. 电台24小时节目榜
  140. 电台24小时主播榜
  141. 电台最热主播榜
  142. 电台主播新人榜
  143. 电台付费精品榜
  144. 歌手热门50首歌曲
  145. 购买数字专辑
  146. 获取 mv 点赞转发评论数数据
  147. 获取视频点赞转发评论数数据
  148. 调整歌单顺序
  149. 调整歌曲顺序
  150. 独家放送列表
  151. 获取推荐视频
  152. 获取视频分类列表
  153. 获取全部视频列表接口
  154. 获取历史日推可用日期列表
  155. 获取历史日推详细数据
  156. 国家编码列表
  157. 首页-发现
  158. 首页-发现-圆形图标入口列表
  159. 数字专辑-全部新碟
  160. 数字专辑-热门新碟
  161. 数字专辑&数字单曲-榜单
  162. 数字专辑-语种风格馆
  163. 数字专辑详情
  164. 更新头像
  165. 歌单封面上传
  166. 楼层评论
  167. 歌手全部歌曲
  168. 精品歌单标签列表
  169. 用户等级信息
  170. 电台个性推荐
  171. 用户绑定信息
  172. 用户绑定手机
  173. 新版评论
  174. 点赞过的视频
  175. 收藏视频到视频歌单
  176. 删除视频歌单里的视频
  177. 最近播放的视频
  178. 音乐日历
  179. 电台订阅者列表
  180. 云贝签到信息
  181. 云贝签到
  182. 云贝所有任务
  183. 云贝todo任务
  184. 云贝今日签到信息
  185. 云贝完成任务
  186. 云贝收入
  187. 云贝支出
  188. 云贝账户信息
  189. 账号信息
  190. 最近联系人
  191. 私信音乐
  192. 抱一抱评论
  193. 评论抱一抱列表
  194. 收藏的专栏
  195. 关注歌手新歌
  196. 关注歌手新MV
  197. 歌手详情
  198. 云盘上传
  199. 二维码登录
  200. 话题详情
  201. 话题详情热门动态
  202. 歌单详情动态
  203. 绑定手机
  204. 一起听状态
  205. 用户历史评论
  206. 云盘歌曲信息匹配纠正
  207. 云贝推歌
  208. 云贝推歌历史记录
  209. 已购单曲
  210. 获取mlog播放地址
  211. 将mlog id转为视频id
  212. vip成长值
  213. vip成长值获取记录
  214. vip任务
  215. 领取vip成长值
  216. 歌手粉丝
  217. 数字专辑详情
  218. 数字专辑销量
  219. 音乐人数据概况
  220. 音乐人播放趋势
  221. 音乐人任务
  222. 账号云豆数
  223. 领取云豆
  224. 获取 VIP 信息
  225. 音乐人签到
  226. 发送文本动态
  227. 获取客户端歌曲下载 url
  228. 获取歌单所有歌曲
  229. 乐签信息
  230. 最近播放-歌曲
  231. 最近播放-视频
  232. 最近播放-声音
  233. 最近播放-歌单
  234. 最近播放-专辑
  235. 最近播放-播客
  236. 签到进度
  237. 重复昵称检测
  238. 歌手粉丝数量
  239. 音乐人任务(新)
  240. 内部版本接口
  241. 歌单更新播放量
  242. 黑胶时光机
  243. 音乐百科 - 简要信息
  244. 乐谱列表
  245. 乐谱内容
  246. 曲风列表
  247. 曲风偏好
  248. 曲风详情
  249. 曲风-歌曲
  250. 曲风-专辑
  251. 曲风-歌单
  252. 曲风-歌手
  253. 私信和通知接口
  254. 回忆坐标
  255. 播客搜索
  256. 播客声音上传
  257. 验证接口-二维码生成
  258. 验证接口-二维码检测
  259. 听歌识曲
  260. 根据nickname获取userid接口
  261. 播客声音列表
  262. 专辑简要百科信息
  263. 歌曲简要百科信息
  264. 歌手简要百科信息
  265. mv简要百科信息
  266. 搜索歌手
  267. 用户贡献内容
  268. 用户贡献条目、积分、云贝数量
  269. 年度听歌报告
  270. 播客声音搜索

更新日志

changelog

单元测试

$ npm test

单元测试 单元测试

SDK

语言 作者 地址 类型
Java JackuXL https://github.com/JackuXL/NeteaseCloudMusicApi-SDK 第三方
Java 1015770492 https://github.com/1015770492/yumbo-music-utils 第三方

贡献者

License

The MIT License (MIT)