亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序如何播放騰訊視頻的實現(xiàn)

 更新時間:2019年09月20日 14:42:50   作者:popper小P  
這篇文章主要介紹了微信小程序如何播放騰訊視頻的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1.背景

因為當(dāng)時需要做視頻播放,后臺存放視頻文件又不現(xiàn)實。所以,做了一個能解析騰訊視頻地址的并播放視頻的小程序。

2.介紹

小程序里的解析騰訊視頻地址的代碼是參考了一個開源項目you-get寫的,把里面的騰訊視頻下載的python代碼寫成了JS代碼。

3.騰訊視頻ID從哪獲取

1.一般播放一個騰訊視頻的時候播放地址為https://v.qq.com/x/page/w0647n5294g.html。
.html到最后一個/之間的字符串即為騰訊視頻id。如https://v.qq.com/x/page/w0647n5294g.html的id為w0647n5294g。

4.獲取騰訊視頻真實播放地址

分為以下兩步

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,即為騰訊視頻的真實地址。把這個地址放到小程序的video組件的src中,即可播放騰訊上的視頻。

最后放上demo:weChatVideoPlay

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript中動態(tài)向表格添加數(shù)據(jù)

    JavaScript中動態(tài)向表格添加數(shù)據(jù)

    本文給大家分享使用原生javascript實現(xiàn)動態(tài)向表格中添加數(shù)據(jù)的方法,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-01-01
  • webpack打包中path.resolve(__dirname, 'dist')的含義解析

    webpack打包中path.resolve(__dirname, 'dist')的含義解

    這篇文章主要介紹了webpack打包中path.resolve(__dirname, 'dist')的含義解析,path:path.resolve(__dirname, 'dist')就是在打包之后的文件夾上拼接了一個文件夾,在打包時,直接生成,本文給大家講解的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • javascript自適應(yīng)寬度的瀑布流實現(xiàn)思路

    javascript自適應(yīng)寬度的瀑布流實現(xiàn)思路

    這里主要介紹瀑布流的一種實現(xiàn)方法:絕對定位(css)+javascript+ajax+json。簡單一點如果不做滾動加載的話就是絕對定位(css)+javascript了,ajax和json是滾動加載更多內(nèi)容的時候用到的,感興趣的你可以參考下哦
    2013-02-02
  • 小程序?qū)崿F(xiàn)圖片移動縮放效果

    小程序?qū)崿F(xiàn)圖片移動縮放效果

    這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)圖片移動縮放效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • js實現(xiàn)圖片放大展示效果

    js實現(xiàn)圖片放大展示效果

    這篇文章主要介紹了js實現(xiàn)圖片放大展示效果,點擊圖片可查看放大效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 微信小程序五星評分效果實現(xiàn)代碼

    微信小程序五星評分效果實現(xiàn)代碼

    這篇文章主要介紹了微信小程序五星評分效果實現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • uniapp實現(xiàn)微信一鍵登錄按鈕樣式(膠囊按鈕的樣式)

    uniapp實現(xiàn)微信一鍵登錄按鈕樣式(膠囊按鈕的樣式)

    這篇文章主要介紹了uniapp實現(xiàn)微信一鍵登錄按鈕樣式,如何開發(fā)膠囊按鈕的樣式,需要的朋友可以參考下
    2024-07-07
  • 詳解JavaScript中Promise的原理與應(yīng)用

    詳解JavaScript中Promise的原理與應(yīng)用

    Promise是JavaScript中的一個重要概念,也是現(xiàn)代JavaScript開發(fā)中必不可少的一部分,本文主要介紹了Promise的實現(xiàn)原理、使用方法及常見應(yīng)用場景,需要的可以收藏一下
    2023-06-06
  • javascript下載文件5種方式實例詳解

    javascript下載文件5種方式實例詳解

    在Web開發(fā)中文件下載功能是一個非常常見的功能,這篇文章主要給大家介紹了關(guān)于javascript下載文件5種方式的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • js中常見的6種繼承方式總結(jié)

    js中常見的6種繼承方式總結(jié)

    js中的繼承與其說是對象的繼承,但更像是讓函數(shù)的功能和用法的復(fù)用,下面這篇文章主要給大家介紹了關(guān)于js中常見的6種繼承方式,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01

最新評論