QQ音乐的各种相关API

简介:   QQ音乐的各种相关API 分类: oc2014-01-29 15:34 2676人阅读 评论(2) 收藏 举报 基本上论坛里做在线音乐的都在用百度的API,进来发现百度的API不仅歌曲的质量不可以保证,而且返回信息里面只有URL,没有一些相关的属性信息。
 

QQ音乐的各种相关API

分类: oc
基本上论坛里做在线音乐的都在用百度的API,进来发现百度的API不仅歌曲的质量不可以保证,而且返回信息里面只有URL,没有一些相关的属性信息。所以就想方设法弄到了QQ音乐的API

已经用xCode尝试过并且可行的API:
搜索音乐(歌词)
http://shopcgi.qqmusic.qq.com/fcgi-bin/shopsearch.fcg?value=歌曲名&artist=歌手名&type=qry_song&out=json&page_no=页码&page_record_num=单页记录数量
这个网上搜索不到的,自己用fiddler抓出来的,会返回一个json,注意的是返回的json的key没有用引号引起来而且需要对URL本身和返回的内容使用gb2312编(解)码
看这样一个例子:
 
复制代码
  1.         NSString *title=@"记得";
  2.         NSString *artist=@"林俊杰";
  3.         
  4.         //-使用歌名和歌手执行搜索
  5.         NSString *searchURLString=[NSString stringWithFormat:@"http://shopcgi.qqmusic.qq.com/fcgi-bin/shopsearch.fcg?value=%@&artist=%@&type=qry_song&out=json&page_no=%i&page_record_num=%i",title,artist,1,3];
  6.         searchURLString=[searchURLString stringByAddingPercentEscapesUsingEncoding:NSGB2312StringEndoding];
  7.         NSString *searchResult=[NSString stringWithContentsOfURL:[NSURL URLWithString:searchURLString] encoding:NSGB2312StringEndoding error:nil];
  8.         NSLog(@"%@",searchResult);

就会得到这样的不标准json,之后的步骤简单的就说下,截取searchCallBack()中间的内容,对key进行加引号,然后就可以用json解码框架来解码
 
复制代码
  1. searchCallBack({result:"0",msg:"",totalnum:"138",curnum:"3",search:"记得",songlist:[{idx:"1",song_id:"1679711",song_name:"记得",album_name:"上海老歌 CD07",singer_name:"欧阳飞莺(Chu Shia)",location:"8",singer_id:"16343",album_id:"133528",price:"250"},{idx:"2",song_id:"1516144",song_name:"记得",album_name:"小精选",singer_name:"刘浩龙",location:"3",singer_id:"4797",album_id:"122193",price:"250"},{idx:"3",song_id:"1512932",song_name:"记得(《爱情睡醒了》插曲)",album_name:"爱情睡醒了",singer_name:"林俊杰",location:"8",singer_id:"4286",album_id:"121988",price:"320"}]})


下载歌词
搜索完成后,每首歌曲会对应一个price属性,如果这个属性对应的值是250就说明没有歌词,确认有歌词,就可以用下面的接口下载歌词
http://music.qq.com/miniportal/static/lyric/歌曲id求余100/歌曲id.xml
如果正常会返回这样的xml(json的返回地址没抓到)

看这个例子:
前一个例子中返回的第三首歌有的price属性值为320,表示有歌词,如果下载这首歌的歌词,就用这个url:
http://music.qq.com/miniportal/static/lyric/32/1512932.xml
腾讯就会送回这样的xml
 
复制代码
  1. <lyric>
  2. <![CDATA[
  3. [ti:记得]
  4. [ar:林俊杰]
  5. [al:288966]
  6. [offset:0]
  7. [00:17.55]谁还记得
  8. [00:19.33]是谁先说永远的爱我
  9. [00:26.03]以前的一句话
  10. [00:29.02]是我们以后的伤口
  11. [00:33.75]过了太久
  12. [00:35.47]没人记得当初那些温柔
  13. [00:42.40]我和你手牵手
  14. [00:45.36]说要一起走到最后
  15. [01:06.37]我们都忘了
  16. [01:11.05]这条路走了多久
  17. [01:15.11]心中是清楚的
  18. [01:17.49]有一天有一天都会停的
  19. [01:23.04]让时间说真话
  20. [01:26.94]虽然我也害怕
  21. [01:31.00]在天黑了以后
  22. [01:33.29]我们都不知道会不会有以后
  23. [01:41.82]谁还记得
  24. [01:43.61]是谁先说永远的爱我
  25. [01:50.24]以前的一句话
  26. [01:53.24]是我们以后的伤口
  27. [01:57.77]过了太久
  28. [01:59.44]没人记得当初那些温柔
  29. [02:06.20]我和你手牵手
  30. [02:09.07]说要一起走到最后
  31. [02:30.40]我们都累了
  32. [02:34.44]却没办法往回走
  33. [02:38.34]两颗心都迷惑
  34. [02:40.69]怎么说怎么说都没有救
  35. [02:46.22]亲爱的为什么
  36. [02:50.21]也许你也不懂
  37. [02:54.11]两个相爱的人
  38. [02:56.65]等着对方先说找分开的理由
  39. [03:05.15]谁还记得爱情开始变化的时候
  40. [03:13.52]我和你的眼中
  41. [03:16.49]看见了不同的天空
  42. [03:21.09]走的太远
  43. [03:22.77]终于走到分岔路的路口
  44. [03:29.40]是不是你和我
  45. [03:32.40]要有两个相反的梦
  46. [03:40.84]谁还记得
  47. [03:42.60]是谁先说永远的爱我
  48. [03:49.38]以前的一句话
  49. [03:52.22]是我们以后的伤口
  50. [03:56.82]过了太久
  51. [03:58.44]没人记得当初那些温柔
  52. [04:05.48]我和你手牵手
  53. [04:08.15]说要一起走到最后
  54. [04:21.42]我和你手牵手
  55. [04:24.36]说要一起走到以后
  56. ]]>
  57. </lyric>


如果你用price为250的歌曲对应的id来搜索,比如第一个例子中的第一首歌,那么你使用的这个url:
http://music.qq.com/miniportal/static/lyric/11/16797.xml

那么就会送回404错误信息:
 
复制代码
  1. The requested URL '/miniportal/static/lyric/11/1679711.xml' was not found on this server.


获取专辑插图
如果需要获取专辑插图,就可以使用下面的接口
http://imgcache.qq.com/music/photo/album/专辑id求余100/albumpic_专辑id_0.jpg
看这个例子:
要获取第一个例子的中的第三个结果的专辑插图,就这么用:
http://imgcache.qq.com/music/photo/album/88/albumpic_121988_0 .jpg
就会返回500*500的插图(QQ音乐的插图清晰度很高)

获取排行榜(尚未经过xCode测试)
目前抓到两个排行榜的地址:
新歌榜: http://music.qq.com/musicbox/shop/v3/data/hit/hit_newsong.js
总榜: http://music.qq.com/musicbox/shop/v3/data/hit/hit_all.js

因为还没有进行进一步的尝试就不放例子了

获取音乐地址
http://stream1歌曲信息中的location值.qqmusic.qq.com/3歌曲ID(7位数,不足在前面补0). mp3
例如之前搜索出来的第一首歌的地址应该是:
http://stream18.qqmusic.qq.com/31679711. mp3
第二首歌的地址应该是
http://stream13.qqmusic.qq.com/31516144. mp3

这个仍然在测试中

希望对和我一样正在努力做在线音乐的童鞋有些帮助

[ 此帖被hxy060799在2012-09-09 11:20重新编辑 ]
 
目录
相关文章
|
JSON Java API
基于Qt的音乐播放器(三)通过酷狗音乐的api接口,返回json格式歌曲信息(播放地址,歌词,图片)
基于Qt的音乐播放器(三)通过酷狗音乐的api接口,返回json格式歌曲信息(播放地址,歌词,图片)
基于Qt的音乐播放器(三)通过酷狗音乐的api接口,返回json格式歌曲信息(播放地址,歌词,图片)
|
API 数据格式 JSON
|
API PHP
[源码]随机获取虾米音乐song_id API文件
[源码]随机获取虾米音乐song_id API文件 January 11, 2015 注意:此API请放置于国内主机使用,如香港、北京等等,否则会提示:虾米音乐在您所处的国家或地区暂时无法使用
1082 0
|
API
个人使用七牛云服务API作为非黄钻QQ空间播放背景音乐的用法
七牛文档中心:http://developer.qiniu.com/ 我就是做了一个页面使用API上传文件,然后获取上传的文件链接用在QQ空间,说一下使用音乐的步骤。
1104 0
|
移动开发 API HTML5
Three.js + HTML5 Audio API 打造3D音乐频谱,Let’s ROCK!
继续玩味之前写的音乐频谱作品,将原来在Canvas标签上的 作图利用Three.js让它通过WebGL呈现,这样就打造出了一个全立体感的频谱效果了。 项目详情及源码 项目GitHub地址:https://github.
1559 0
|
API 定位技术
Arcgis api For silverlight 加载QQ地图
原文 http://www.cnblogs.com/thinkaspx/archive/2012/11/07/2759079.html //本篇博客仅在技术上探讨可行性    //如果要使用Q 地图,请联系相关厂商 public class QQMapLayer : TiledMapServi...
794 0