溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

微信小程序中播放騰訊視頻的實(shí)現(xiàn)方法

發(fā)布時(shí)間:2021-02-02 14:57:49 來(lái)源:億速云 閱讀:257 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹了微信小程序中播放騰訊視頻的實(shí)現(xiàn)方法,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1.背景

因?yàn)楫?dāng)時(shí)需要做視頻播放,后臺(tái)存放視頻文件又不現(xiàn)實(shí)。所以,做了一個(gè)能解析騰訊視頻地址的并播放視頻的小程序。

2.介紹

小程序里的解析騰訊視頻地址的代碼是參考了一個(gè)開(kāi)源項(xiàng)目you-get寫(xiě)的,把里面的騰訊視頻下載的python代碼寫(xiě)成了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中,即可播放騰訊上的視頻。

最后放上demo:weChatVideoPlay

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“微信小程序中播放騰訊視頻的實(shí)現(xiàn)方法”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI