QQ音乐API koa2实现 - 全接口实现

QQMusicAPI

QQ音乐API koa2 版本, 通过Web网页版请求QQ音乐接口数据, 有问题请提 issue, 或者你有其他想法欢迎PR.

Github

知乎

掘金

环境要求

因为本项目采用的是koa2, 所以请确保你的node版本是7.6.0+

node -v

安装

git@github.com:Rain120/qq-music-api.git
npm install

项目启动

// npm i -g nodemon
npm run start

// or don't install nodemon
node app.js

项目监听端口是3200

使用文档

使用apis详见文档

关于本人

Rain120: 前端菜鸟, 入职前端1年, 公司的技术栈是React, 因为公司官网由我重构过, 我使用的Vue.js重构的。目前正在脱坑, 求大佬内推呀

API结构图

qq-music

API接口

koa接口说明(参数, 地址, 效果图)

获取QQ音乐产品的下载地址

接口说明: 调用此接口, 可获取QQ音乐标准产品下载链接

接口地址: /downloadQQMusic

调用例子: /downloadQQMusic

示例截图:

获取QQ音乐产品的下载地址

获取歌单分类

接口说明: 调用此接口, 可获取歌单分类, 包含category信息

接口地址: /getSongListCategories

调用例子: /getSongListCategories

SortID
sortId: 1, sortName: 默认
sortId: 2, sortName: 最新
sortId: 3, sortName: 最热
sortId: 4, sortName: 评分
sortId: 5, sortName: none

歌单分类(categoryId & categoryName)

1. 热门
1.1
  "categoryId": 10000000,
  "categoryName": 全部,
2. 语种
2.1
  "categoryId": 167,
  "categoryName": "英语",
2.2
  "categoryId": 168,
  "categoryName": "韩语",
2.3
  "categoryId": 166,
  "categoryName": "粤语",
2.4
  "categoryId": 169,
  "categoryName": "日语",
2.5
  "categoryId": 170,
  "categoryName": "小语种",
2.6
  "categoryId": 203,
  "categoryName": "闽南语",
2.7
  "categoryId": 204,
  "categoryName": "法语",
2.8
  "categoryId": 205,
  "categoryName": "拉丁语",
3. 流派
3.1
  "categoryId": 6,
  "categoryName": "流行",
3.2
  "categoryId": 15,
  "categoryName": "轻音乐",
3.3
  "categoryId": 11,
  "categoryName": "摇滚",
3.4
  "categoryId": 28,
  "categoryName": "民谣",
3.5
  "categoryId": 8,
  "categoryName": "R&B",
3.6
  "categoryId": 153,
  "categoryName": "嘻哈",
3.7
  "categoryId": 24,
  "categoryName": "电子",
3.8
  "categoryId": 27,
  "categoryName": "古典",
3.9
  "categoryId": 18,
  "categoryName": "乡村",
3.10
  "categoryId": 22,
  "categoryName": "蓝调",
3.11
  "categoryId": 21,
  "categoryName": "爵士",
3.12
  "categoryId": 164,
  "categoryName": "新世纪",
3.13
  "categoryId": 25,
  "categoryName": "拉丁",
3.14
  "categoryId": 218,
  "categoryName": "后摇",
3
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,以下是基于 TypeScript、Koakoa-body 实现的文件上传代码示例: ```typescript import Koa from 'koa'; import koaBody from 'koa-body'; const app = new Koa(); // 设置上传文件的保存路径 const uploadDir = './uploads'; // koa-body 中间件配置 const koaBodyConfig = { multipart: true, // 启用文件上传 formidable: { uploadDir, // 文件保存路径 keepExtensions: true, // 保留文件扩展名 }, }; // 注册 koa-body 中间件 app.use(koaBody(koaBodyConfig)); app.use(async (ctx) => { // 判断是否为文件上传请求 if (ctx.request.files && ctx.request.files.file) { const { file } = ctx.request.files; // 输出上传文件信息 console.log(`Received file: ${file.name}`); console.log(`File size: ${file.size}`); console.log(`File path: ${file.path}`); ctx.body = 'File uploaded successfully.'; } else { ctx.body = 'Hello World!'; } }); app.listen(3000, () => { console.log('Server is running on http://localhost:3000'); }); ``` 以上代码中,我们通过 `koa-body` 中间件启用了文件上传功能,并且设置了上传文件的保存路径。当接收到文件上传请求时,我们可以通过 `ctx.request.files.file` 获取上传的文件信息,然后对文件进行处理。如果不是文件上传请求,我们只是简单地返回了一个 "Hello World!" 字符串。 注意,我们在代码中没有对文件进行任何处理,只是输出了一些文件信息。在实际项目中,我们需要对上传的文件进行校验、存储和处理。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值