小程序获取QQ音乐播放链接插件

最近参加了一个微信小程序开发大赛,其中用到了音乐播放功能。于是在小程序官方文档和插件库中逛了一圈,但是官方没有提供对QQ音乐的搜索和获取播放链接等支持,插件库中的插件寥寥无几,并不好用。无奈之下只好自己写一个关于QQ音乐的插件,来完成相应的搜索,获取播放链接等功能。

在开始介绍插件功能之前,特别感谢简书tisa提供了QQ音乐相应的api。这个插件就是基于这些api进行的封装。

这一篇文章本来是用markdown编写的,但是无法设置为公开文章,因此没有代码块,代码部分显得比较难看。

插件项目地址:https://github.com/FisherWY/QQMusicPlugin

下面正式开始介绍插件使用方法:

1. 前往下载页面,下载最新的v0.2版本,将下载的文件解压放在小程序utils文件夹中,解压后的文件目录结构如下图所示:

QQMusicPlugin文件夹在utils目录之下

2. 前往微信公众平台->开发->开发设置->服务器域名。添加以下request合法域名,该域名用于音乐的搜索等

https://c.y.qq.com

添加request合法域名步骤

3. 在小程序页面js文件中引用qqMusicTools.js,注意相对路径,这里演示的页面路径为"/pages/index/"

const musicTool = require("../../utils/QQMusicPlugin/qqMusicTools.js")

在需要用到接口的页面js文件中引用插件

4. 搜索音乐接口searchMusic。(使用PromiseJS语法)

接口参数说明:

page:搜索页码

number:每页搜索记录数量

keyword:搜索关键字

musicTool.searchMusic(1, 10, "墙纸").then(function(searchRes) {

    console.log(searchRes)

})

搜索接果如下图:

搜索音乐返回结果

5. 获取播放音乐链接接口playMusic接受1个参数:filename。表示要播放的音乐的文件名,文件名来自searchMusic结果中的"songmid"。(使用PeomiseJS语法)

接口参数说明:

filename:要播放的音乐的文件名,文件名来自searchMusic结果中的"songmid"

musicTool.playMusic("0021rBlZ1gQiLy").then(function(playRes) {

    console.log(playRes)

})

返回结果如下图:

返回了音乐的播放链接

6. 获取音乐专辑图片接口getAlbumImage。(使用Promise语法)(在v0.1版本中,搜索音乐接口已经集成了该接口,专辑图片字段名为"albumImg")

参数说明:

albumId:该参数来自searchMusic结果中的"albumId"。

musicTool.getAlbumImage(6271293).then(function(res) {

    console.log(res)

})

返回结果如下图:

返回了专辑图片链接

7. 获取热门音乐榜Top100歌单接口getTopMusic不需要任何参数,直接调用即可获得返回结果。(使用Promise语法)

musicTool.getTopMusic().then(function(res) {

  console.log(res)

})

返回结果如下图:

Top100歌单列表

8. 随机推荐歌单接口radomRecommend不需要任何参数,直接调用即可获得返回结果。(使用Promise语法)

musicTool.randomRecommend().then(function(res) {

  console.log(res)

})

返回结果如下图:

随机推荐歌单列表

9. 播放音乐,这里使用BackgroundAudioManager演示

// 获取全局唯一的背景音乐管理器

const bgAudioManager = wx.getBackgroundAudioManager()

// 音乐标题

bgAudioManager.title = 'Music'

// 音乐歌手名

bgAudioManager.singer = 'Singer'

// 专辑封面图片

bgAudioManager.coverImgUrl = 'imgUrl'

// 音乐播放链接,设置后自动开始播放

bgAudioManager.src = playRes

10. 代码整合到一块,整个使用流程如下。(需要注意异步问题):

const bgAudioManager = wx.getBackgroundAudioManager();

musicTool.searchMusic(1, 10, "绿色").then(function(searchRes) {

    console.log(searchRes)

})

musicTool.playMusic("0021rBlZ1gQiLy").then(function(playRes) {

    console.log(playRes)

    bgAudioManager.title = 'Music'

    bgAudioManager.src = playRes

})

musicTool.getAlbumImage(6271293).then(function(res) {

    console.log(res)

})

// 获取top100音乐

musicTool.getTopMusic().then(function(res) {

    console.log(res)

})

// 随机推荐音乐

musicTool.randomRecommend().then(function(res) {

    console.log(res)

})

11. 特别说明:

1. 当要播放的音乐属于收费音乐时无法播放 ,具体表现为获取token返回值为空

2. 请求过程中需要注意js中的异步问题 

3. 微信小程序的BackgroundAudioManager存在部分链接无法播放的问题,因此建议使用InnerAudioContext,无法播放的详细原因参见JabinGP的简书

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,179评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,229评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,032评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,533评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,531评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,539评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,916评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,813评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,568评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,654评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,354评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,918评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,152评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,852评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,378评论 2 342