首页 > 开发 > Javascript > 正文

jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例

2019-10-26 20:51:26
字体:
来源:转载
供稿:网友
本文为大家介绍下jQuery+JSON+jPlayer实现QQ空间音乐查询,具体的实现过程感兴趣的朋友可以了解下哈,希望对大家有所帮助

jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例


演示地址:
代码下载:
查询QQ音乐是很早前就出来的一个接口。
这里使用jQuery和jPlayer来实现QQ空间音乐的查询。
首先感谢bejson收集的各种有用的接口,当然也包含QQ空间音乐接口。
它的网址是:
我们要使用的接口位于bejson接口页面中的音乐接口栏里。
QQ音乐接口地址:
?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接口

jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例


我们来解析音乐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"
});
}

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表