jQuery+JSON+jPlayer实现QQ空间音乐查询

网友投稿 887 2022-08-02

查询QQ音乐是很早前就出来的一个接口

jQuery+JSON+jPlayer实现QQ空间音乐查询

这里使用jQuery和jPlayer来实现QQ空间音乐的查询。

我们要使用的接口位于bejson接口页面中的音乐接口栏里。

QQ音乐接口地址:

http://qzone-music.qq.com/fcg-bin/fcg_music_fav_getinfo.fcg?dirinfo=0&dirid=1&uin=QQ号&p=0.519638272547262&g_tk=1284234856

这里给出核心代码:

1.gtk参数的获取方式

function getGTK() {

var str = "@HR3etVm80";

var hash = 5381;

for (var i = 0,

len = str.length; i < len; ++i) {

hash += (hash << 5) + str.charAt(i).charCodeAt();

}

var gtk = hash & 0x7fffffff;

//document.getElementById("gtk").value = gtk;

return gtk;

}

2.请求QQ空间接口

function getMusicId() {

var qqNo = document.getElementById("qqNo").value;

var url = 'http://qzone-music.qq.com/fcg-bin/cgi_playlist_xml.fcg?uin=' + qqNo + '&json=1&g_tk=' + getGTK();

$.getScript(url);

}

3.回调拼装JSON

根据返回的JSON接口

我们来解析音乐JSON

function jsonCallback(data) {

if(data.code==1){

alert(data.msg);

return;

}

var songs = data.qqmusic.playlist.song;

var dataStr = "[";

for (var i = 0; i < songs.length; i++) {

dataStr += "{";

dataStr += "title:'" + songs[i].xsong_name + "',";

dataStr += "mp3:'" + songs[i].xsong_url + "'";

dataStr += "}";

if (i < songs.length) {

dataStr += ',';

}

}

dataStr += ']';

eval("ds=" + dataStr);

newPlayer(ds);

}

最后我们调用jPlay播放器:

var playList;

function newPlayer(data) {

playList = new jPlayerPlaylist({

jPlayer: "#jquery_jplayer_1",

cssSelectorAncestor: "#jp_container_1"

},

data, {

swfPath: "js",

supplied: "mp3",

wmode: "window"

});

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:jQuery+JSONP通过调用虾米接口实现类似点点网发布音乐的功能
下一篇:什么是JSONP,JSON和JSONP的联系和区别详解(jsonp数据格式)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~