微信小程序如何播放騰訊視頻的實(shí)現(xiàn)
1.背景
因?yàn)楫?dāng)時(shí)需要做視頻播放,后臺(tái)存放視頻文件又不現(xiàn)實(shí)。所以,做了一個(gè)能解析騰訊視頻地址的并播放視頻的小程序。
2.介紹
小程序里的解析騰訊視頻地址的代碼是參考了一個(gè)開源項(xiàng)目you-get寫的,把里面的騰訊視頻下載的python代碼寫成了JS代碼。
3.騰訊視頻ID從哪獲取
1.一般播放一個(gè)騰訊視頻的時(shí)候播放地址為https://v.qq.com/x/page/w0647n5294g.html。
.html到最后一個(gè)/之間的字符串即為騰訊視頻id。如https://v.qq.com/x/page/w0647n5294g.html的id為w0647n5294g。
4.獲取騰訊視頻真實(shí)播放地址
分為以下兩步
1 獲取視頻信息
把騰訊視頻ID傳入以下函數(shù)
getVideoInfo: function (vid) {
var that = this;
var urlString = 'https://vv.video.qq.com/getinfo?otype=json&appver=3.2.19.333&platform=11&defnpayver=1&vid=' + vid;
wx.request({
url: urlString,
success: function (res) {
var dataJson = res.data.replace(/QZOutputJson=/, '') + "qwe";
var dataJson1 = dataJson.replace(/;qwe/, '');
var data = JSON.parse(dataJson1);
var fn_pre = data.vl.vi[0].lnk
host = data['vl']['vi'][0]['ul']['ui'][0]['url']
var streams = data['fl']['fi']
var seg_cnt = data['vl']['vi'][0]['cl']['fc']
if (parseInt(seg_cnt) == 0) {
seg_cnt = 1
}
var best_quality = streams[streams.length - 1]['name']
var part_format_id = streams[streams.length - 1]['id']
for (var i = 1; i < (seg_cnt + 1); i++) {
var filename = fn_pre + '.p' + (part_format_id % 10000) + '.' + i + '.mp4';
console.log(filename);
pageArr.push(i);
that.requestVideoUrls(part_format_id, vid, filename, 'index' + i);
}
}
})
},
2 根據(jù)視頻信息解析視頻真正的播放地址
requestVideoUrls: function (part_format_id, vid, fileName, index) {
var keyApi = "https://vv.video.qq.com/getkey?otype=json&platform=11&format=" + part_format_id + "&vid=" + vid + "&filename=" + fileName + "&appver=3.2.19.333"
var that = this;
wx.request({
url: keyApi,
success: function (res) {
var dataJson = res.data.replace(/QZOutputJson=/, '') + "qwe";
var dataJson1 = dataJson.replace(/;qwe/, '');
var data = JSON.parse(dataJson1);
if (data.key != undefined) {
var vkey = data['key']
var url = host + fileName + '?vkey=' + vkey;
part_urls[index] = String(url)
that.setData({
videoUrl: part_urls.index1
});
}
}
})
},
該函數(shù)里面的part_urls.index1,即為騰訊視頻的真實(shí)地址。把這個(gè)地址放到小程序的video組件的src中,即可播放騰訊上的視頻。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript onkeydown,onkeyup,onkeypress,onclick,ondblclick
昨天群里面的朋友問(wèn)了個(gè)比較有意思的問(wèn)題,keydown,keyup,keypress事件的先后順序。2009-02-02
js中的escape及unescape函數(shù)的php實(shí)現(xiàn)代碼
js中的escape及unescape函數(shù)的php實(shí)現(xiàn)代碼...2007-09-09
javascript比較兩個(gè)日期相差天數(shù)的方法
這篇文章主要介紹了javascript比較兩個(gè)日期相差天數(shù)的方法,涉及javascript針對(duì)日期的轉(zhuǎn)換與數(shù)學(xué)運(yùn)算相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-07-07
Javascript判斷對(duì)象是否相等實(shí)現(xiàn)代碼
想判斷2個(gè)js對(duì)象,是不是所有完全相同在表單頁(yè)面應(yīng)用是很常見(jiàn)的,接下來(lái)分享一段判斷代碼,感興趣的你可以參考下哈,希望可以幫助到你2013-03-03
layui的布局和表格的渲染以及動(dòng)態(tài)生成表格的方法
今天小編就為大家分享一篇layui的布局和表格的渲染以及動(dòng)態(tài)生成表格的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09

