微信小程序如何播放騰訊視頻的實(shí)現(xiàn)
1.背景
因?yàn)楫?dāng)時(shí)需要做視頻播放,后臺(tái)存放視頻文件又不現(xiàn)實(shí)。所以,做了一個(gè)能解析騰訊視頻地址的并播放視頻的小程序。
2.介紹
小程序里的解析騰訊視頻地址的代碼是參考了一個(gè)開(kāi)源項(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中動(dòng)態(tài)向表格添加數(shù)據(jù)
本文給大家分享使用原生javascript實(shí)現(xiàn)動(dòng)態(tài)向表格中添加數(shù)據(jù)的方法,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-01-01webpack打包中path.resolve(__dirname, 'dist')的含義解
這篇文章主要介紹了webpack打包中path.resolve(__dirname, 'dist')的含義解析,path:path.resolve(__dirname, 'dist')就是在打包之后的文件夾上拼接了一個(gè)文件夾,在打包時(shí),直接生成,本文給大家講解的非常詳細(xì),需要的朋友可以參考下2023-05-05javascript自適應(yīng)寬度的瀑布流實(shí)現(xiàn)思路
這里主要介紹瀑布流的一種實(shí)現(xiàn)方法:絕對(duì)定位(css)+javascript+ajax+json。簡(jiǎn)單一點(diǎn)如果不做滾動(dòng)加載的話就是絕對(duì)定位(css)+javascript了,ajax和json是滾動(dòng)加載更多內(nèi)容的時(shí)候用到的,感興趣的你可以參考下哦2013-02-02微信小程序五星評(píng)分效果實(shí)現(xiàn)代碼
這篇文章主要介紹了微信小程序五星評(píng)分效果實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-04-04uniapp實(shí)現(xiàn)微信一鍵登錄按鈕樣式(膠囊按鈕的樣式)
這篇文章主要介紹了uniapp實(shí)現(xiàn)微信一鍵登錄按鈕樣式,如何開(kāi)發(fā)膠囊按鈕的樣式,需要的朋友可以參考下2024-07-07詳解JavaScript中Promise的原理與應(yīng)用
Promise是JavaScript中的一個(gè)重要概念,也是現(xiàn)代JavaScript開(kāi)發(fā)中必不可少的一部分,本文主要介紹了Promise的實(shí)現(xiàn)原理、使用方法及常見(jiàn)應(yīng)用場(chǎng)景,需要的可以收藏一下2023-06-06