2019最新QQ音乐Api

下面的请求中如果参数有songmid,都是得经过搜索歌曲或歌手后才能获得songmid,然后进行请求。不能获取到qq音乐的vip或者付费歌曲的播放地址,Api是通过fiddler4爬取网页端qq音乐获取的,如失效,请在评论指出

前言

最近重构了自己的安卓版的音乐播放器,主要是因为之前使用的音乐相关Api都失效了,索性自己来找Api,于是利用fiddler4爬取网页端qq音乐获取到了项目所需要的Api,途中也遇到了许多坑,但是通过自己的努力解决了问题,所以在这里分享一波!

一、 搜索

1.搜索歌手/歌曲

请求地址:https://c.y.qq.com

请求示例:https://c.y.qq.com/soso/fcgi-bin/client_search_cp?p=1&n=2&w=泡沫&format=json

说明:关键字为歌手就返回该歌手的歌曲,如果为歌曲就返回该歌曲列表

参数说明是否必须默认值
p分页默认为1
n请求数量默认为10
w关键字
format格式化如果用Retrofit的Json解析的话记得一定要format=json

2.搜索专辑

请求地址:https://c.y.qq.com

请求示例:https://c.y.qq.com/soso/fcgi-bin/client_search_cp?p=1&n=2&w=邓紫棋&format=json&t=8

参数说明是否必须默认值
p分页默认为1
n请求数量默认为10
w关键字
format格式化如果用Retrofit的Json解析的话记得一定要format=json
t类别没有默认值,如果为搜索专辑,则t为8。如果是搜索mv,t=12。

二、 获取图片

1.根据歌手获取图片

请求地址:http://music.163.com

请求示例:http://music.163.com/api/search/get/web?s=邓紫棋&type=100

说明:请求后将有歌手图片的字段,请求后的picUrl和img1v1Url就是图片地址

参数说明是否必须默认值
s歌手
type类别无,但必须为100

!!!注意:有可能在网上能够请求到数据,但在实际代码中请求时却不能返回的情况(自己在开发中碰到),这时候别着急,只需要在网络请求时加上请求头**“User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36”**就能解决问题!

2. 根据albumMID获取专辑图片

请求地址:http://y.gtimg.cn

请求示例:http://y.gtimg.cn/music/photo_new/T002R180x180M000003c616O2Zlswm.jpg

说明:请求示例其实有两部分组成,即固定地址+albumMid。

组成说明
固定地址http://y.gtimg.cn/music/photo_new/T002R180x180M000固定值,不需要改变
albumMid在搜索专辑后,或者搜索歌曲会有albumMid这个字段需要先搜索后得到albumMid

三、 获取播放地址

如果用的是Retrofit请求,则需要在请求时加上encoded = true的参数,不然请求时会出现-500001的错误。代码示例:

@GET(Api.SONG_URL)
Observable<SongUrl> getSongUrl(@Query(value = "data",encoded = true) >String data);

请求地址:https://u.y.qq.com

请求示例:https://u.y.qq.com/cgi-bin/musicu.fcg?format=json&data=%7B%22req_0%22%3A%7B%22module%22%3A%22vkey.GetVkeyServer%22%2C%22method%22%3A%22CgiGetVkey%22%2C%22param%22%3A%7B%22guid%22%3A%22358840384%22%2C%22songmid%22%3A%5B%22001X0PDf0W4lBq%22%5D%2C%22songtype%22%3A%5B0%5D%2C%22uin%22%3A%221443481947%22%2C%22loginflag%22%3A1%2C%22platform%22%3A%2220%22%7D%7D%2C%22comm%22%3A%7B%22uin%22%3A%2218585073516%22%2C%22format%22%3A%22json%22%2C%22ct%22%3A24%2C%22cv%22%3A0%7D%7D

说明:这个是根据歌曲songmid来获得音乐播放地址的,请求示例很长,在经过多次尝试后,很遗憾的并不能缩减,要想获取播放地址,只需要更改上面蓝色字体的songmid后的001X0PDf0W4lBq即可,至于更改方法很多,比如直接用Java的字符串拼接。请求成功后请注意两个字段purl和sip(为数组),歌曲的播放地址就是sip数组里的其中一个加上pur,即sip[0]+purl(vip音乐或者版权音乐的purl为空)。

1. 请求时的参数说明

参数说明
songmid歌曲的songmid怎么得到,必须通过上面搜索歌曲后得到,然后更改上面示例的001X0PDf0W4lBq(泡沫的songmid)即可,示例的其它地方都不能做更改,也不能删减

2.请求后重要字段解释

播放地址:sip[0]+purl

示例:http://ws.stream.qqmusic.qq.com/C400000HjG8v1DTWRO.m4a?guid=358840384&vkey=852D30CD2DEA9E0AFF9CF700977FAFB413A06486CFE8F72502918665277C5407D8D5AD42039F02329401300003A2853B10816B83C3145159&uin=0&fromtag=66(泡沫)

字段说明示例
sip播放接口地址,目前来说有两个地址,但是很有可能会改变“sip”: [
“http://ws.stream.qqmusic.qq.com/”,
“http://isure.stream.qqmusic.qq.com/”
]
purl里面最重要的就是vkey的值,这个值每次请求都不一样C400000HjG8v1DTWRO.m4a?guid=358840384&
vkey=852D30CD2DEA9E0AFF9CF700977FAFB413A06486CFE8F7250
2918665277C5407D8D5AD42039F02329401300003A2853B10816B83C3145159
&uin=0&fromtag=66

四、 获取歌词

请求地址:https://c.y.qq.com

请求示例:https://c.y.qq.com/lyric/fcgi-bin/fcg_query_lyric_new.fcg?songmid=000wocYU11tSzS&format=json&nobase64=1

说明:如果你点击了上面的链接的话,你会发现返回的是-1310的错误码,这时候请别着急,并不是这个请求Api是无效的,只是因为这个获取歌词的Api有点特殊,在请求时需要在请求的header上加上Referer地址就可以了

参数说明
songmid歌曲songmid,需要在搜索歌曲后获取
format格式,建议加上format=json
nobase64敲重点!!!,一定要等于1,默认是0,如果没加上的话,返回的歌词将会是乱码,加上后就可以得到歌曲的动态歌词,即带有时间的歌词

!!!敲重点:记得在请求头上加上Referer:https://y.qq.com/portal/player.html,不然请求会返回-1310

加Header(安卓)

1. OkHttp

Request request = new Request.Builder()
                            .url(baseUrl)
                            .addHeader("Referer","https://y.qq.com/portal/player.html")
                            .build();

2. Retrofit
直接在@GET上面加上Headers注解

@Headers(Referer:https://y.qq.com/portal/player.html)

另外对音乐播放器自定义View歌词实现有兴趣的话可以看看这篇博客
Android自定义View-简约风歌词控件

  • 26
    点赞
  • 108
    收藏
    觉得还不错? 一键收藏
  • 26
    评论
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值