欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#結(jié)合JavaScript實現(xiàn)上傳視頻到騰訊云點播平臺的操作方法

 更新時間:2023年11月23日 10:29:27   作者:初九之潛龍勿用  
這篇文章主要介紹了C#結(jié)合JavaScript實現(xiàn)上傳視頻到騰訊云點播平臺,上傳視頻功能,主要要解決兩個問題,一是在服務端通過C#生成簽名和SDKID,二是在客戶端通過JavaScript上傳視頻到騰訊云點播服務器,感興趣的朋友跟隨小編一起看看吧

需求

在云培訓系統(tǒng)里,制作視頻課件是我們的主要工作之一,制作完成后如果將這些素材存儲到服務器并進行分發(fā)播放,是擺在我們面前的一個問題。最終我們選擇了騰訊云點播服務,其加速分發(fā)播放幾乎適用所有需要展示圖片或音視頻媒體內(nèi)容的在線場景,借助遍布全球的大量 CDN 加速節(jié)點,在復雜的網(wǎng)絡環(huán)境也能提供高質(zhì)量的媒體內(nèi)容訪問服務。

上傳視頻功能,主要要解決兩個問題:

1、在服務端通過C#生成簽名和SDKID

2、在客戶端通過JavaScript上傳視頻到騰訊云點播服務器。

關鍵代碼

界面元素布局

放置一個DIV容器,包括 file 上傳控件(id:file1)、一個上傳進度條的灰色背景層(id:ajax_uploadFiles_curbg)、一個傳進度條的進度圖片(id:ajax_uploadFiles_curprogress)、一個提示文字層(id:tip),圖片及層采用絕對定位,并在上傳過程中計算進度值以決定進度圖片的寬度。

示例代碼如下:

<div>
<input type="file" accept=".mp4,.mp3" id="file1"  onchange="vUpload()" />
<img id="ajax_uploadFiles_curprogress" style="z-index:1;position:absolute;left:0px;top:4px;width:0px;height:12px" alt="" src="win7progress.jpg" />
<div id="ajax_uploadFiles_curbg" style="display:none;z-index:0;position:absolute;left:0px;top:4px;width:203px;height:12px;background-color:Gray"></div>
<div id="tip" style="z-index:0;position:absolute; font-size:9pt;left:205px;top:2px;height:12px;"></div>
</div>

C# 實現(xiàn)服務端的簽名類

上傳之前需要提供您的開發(fā)APPID和開發(fā)密鑰,以生成有效的簽名,才可以進行上傳操作,示例代碼如下:

public class Signature
         {
             public string m_strSecId;
             public string m_strSecKey;
             public int m_iRandom;
             public long m_qwNowTime;
             public int m_iSignValidDuration;
             public static long GetIntTimeStamp()
             {
                 TimeSpan ts = DateTime.UtcNow - new DateTime(1970, 1, 1);
                 return Convert.ToInt64(ts.TotalSeconds);
             }
             private byte[] hash_hmac_byte(string signatureString, string secretKey)
             {
                 var enc = Encoding.UTF8; HMACSHA1 hmac = new HMACSHA1(enc.GetBytes(secretKey));
                 hmac.Initialize();
                 byte[] buffer = enc.GetBytes(signatureString);
                 return hmac.ComputeHash(buffer);
             }
             public string GetUploadSignature()
             {
                 string strContent = "";
                 strContent += ("secretId=" + Uri.EscapeDataString((m_strSecId)));
                 strContent += ("&currentTimeStamp=" + m_qwNowTime);
                 strContent += ("&expireTime=" + (m_qwNowTime + m_iSignValidDuration));
                 strContent += ("&random=" + m_iRandom);
                 byte[] bytesSign = hash_hmac_byte(strContent, m_strSecKey);
                 byte[] byteContent = System.Text.Encoding.Default.GetBytes(strContent);
                 byte[] nCon = new byte[bytesSign.Length + byteContent.Length];
                 bytesSign.CopyTo(nCon, 0);
                 byteContent.CopyTo(nCon, bytesSign.Length);
                 return Convert.ToBase64String(nCon);
             }
             public string getSign(int SignValidSeconds){
                 Signature sign = new Signature();
                 sign.m_strSecId = secretId;   //開發(fā)ID
                 sign.m_strSecKey = secretKey; //開發(fā)密鑰
                 sign.m_qwNowTime = Signature.GetIntTimeStamp();
                 sign.m_iRandom = new Random().Next(0, 1000000);
                 sign.m_iSignValidDuration = SignValidSeconds;
                 return rv = "{\"errcode\":0,\"sign\":\"" + sign.GetUploadSignature() + "\",\"sdkid\":\"1111111111\"}";    
             }
         }

調(diào)用 Signature類的 getSign(int SignValidSeconds) 方法生成簽名,參數(shù)為簽名有效期的秒數(shù)。 

上傳視頻的JS實現(xiàn)

實現(xiàn)功能之前需要引用一些必要的JS文件,我的資源下載鏈接地址:http://xiazai.jb51.net/202311/yuanma/poi_nojar_jb51.rar

//引用必要的三個js
<script src="jquery-3.2.1.min.js"></script>
  <script src="es6-promise.auto.js"></script>
  <script src="vod-js-sdk-v6.js"></script>
  <script type="text/javascript">
      var sign = "";
      var sdkid="";
      var tcVod = null;
      var timer=null;
      var ws=0;
      var fileobj=document.getElementById('file1');
      var curbg=document.getElementById('ajax_uploadFiles_curbg');
      var progressBarWidth=parseInt(curbg.style.width,10);
//重新或嘗試獲取sign
      function resign() {
          return sign;
      }
//與服務器API地址交互獲得簽名值和SDKID,有效時間為3600秒
      function getsign() {
          $.ajax({
              type: "Post",
              url: '<%=ViewState["apiurl"].ToString()%>',
              contentType: "application/x-www-form-urlencoded;charset=utf-8",
              data: {
                  validSeconds: 3600
              },
              dataType: "json",
              success: function (res) {
                  //返回的數(shù)據(jù)用data.d獲取內(nèi)容   
                  if (res.errcode == 0) {
                      sign = res.sign;
                      sdkid=res.sdkid;
                      initTcVod();
                  } else {
                      alert('上傳暫時無法使用。');
                  }
              },
              error: function (err) {
                      alert(err);
              }
          });
      }
      getsign();  //獲取一次簽名值
     function timetip(off) {
        var z = parseInt(off / 60, 10);
        var y = off % 60;
        var mtip='';
        var stip='';
        if(z==0&&y!=0){
          stip=y+'秒';
        } else if (z != 0 && y == 0) {
          mtip = z +'分鐘';
        } else if (z != 0 && y != 0) {
          mtip = z + '分';
          stip = y + '秒';
        }  
        return mtip+stip;
    }
//初始化騰訊上傳組件
      function initTcVod() {
          tcVod = new TcVod.default({getSignature: resign});
      }
//上傳視頻
            function vUpload(){
                  ws=0;
                  curbg.style.display='';
                  timer=window.setInterval(function(){ws++},1000);
                  var mediaFile = document.getElementById('file1').files[0];
                  var uploader = tcVod.upload({
                    mediaFile: mediaFile,mediaName:sdkid+mediaFile.name,
                  });
                  uploader.on('media_progress', function (info) {
                    fileobj.style.display='none';
                    document.getElementById('tip').innerHTML='已上傳'+ Math.round(info.percent*100)+'%(耗時'+timetip(ws)+')';
                    document.getElementById('ajax_uploadFiles_curprogress').style.width=(progressBarWidth*info.percent)+'px';
                  })
                  uploader.on('media_upload', function (info) {
                    window.clearInterval(timer);
                    document.getElementById('tip').innerHTML='上傳成功!';
                    執(zhí)行后續(xù)操作...
                    }else{
                    }
                  })
            }
  </script>

視頻演示

JS上傳視頻到騰訊云點播

小結(jié)

以上提供的代碼僅供參考,在實際的應用中,服務端 API URL 程序還需要身份驗證或即時令牌訪問等安全機制。

另外騰訊云媒體上傳還提供了多種上傳方式的SDK,具體可參考網(wǎng)址:

https://cloud.tencent.com/document/product/266/9760

到此這篇關于C#結(jié)合JavaScript實現(xiàn)上傳視頻到騰訊云點播平臺的文章就介紹到這了,更多相關C#騰訊云點播平臺內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解C#如何優(yōu)雅地終止線程

    詳解C#如何優(yōu)雅地終止線程

    在大多情況下,我們只關心線程的創(chuàng)建與啟動,運行,卻并不關心線程的結(jié)束或者終止。今天這篇文章,我們就以一些簡單的小例子,簡述如何有效的停止線程,僅供學習分享使用,如有不足之處,還請指正
    2023-03-03
  • C# using()的使用方法

    C# using()的使用方法

    本文主要介紹了C# using()的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • C#中類與接口的區(qū)別個人總結(jié)

    C#中類與接口的區(qū)別個人總結(jié)

    這篇文章主要介紹了C#中類與接口的區(qū)別個人總結(jié),本文講解了類與接口的區(qū)別、接口的用處主要體現(xiàn)在下面幾個方面、一些接口的疑問等內(nèi)容,需要的朋友可以參考下
    2015-06-06
  • 基于c# 接口的實例詳解

    基于c# 接口的實例詳解

    本篇文章是對c#中的接口進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • C#實現(xiàn)MQTT服務端與客戶端通訊功能

    C#實現(xiàn)MQTT服務端與客戶端通訊功能

    這篇文章介紹了C#實現(xiàn)MQTT服務端與客戶端通訊的功能,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • Unity實現(xiàn)單機游戲每日簽到系統(tǒng)

    Unity實現(xiàn)單機游戲每日簽到系統(tǒng)

    這篇文章主要為大家詳細介紹了Unity實現(xiàn)單機游戲每日簽到系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • C# XmlDocument操作XML案例詳解

    C# XmlDocument操作XML案例詳解

    這篇文章主要介紹了C# XmlDocument操作XML案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • unity通過Mesh網(wǎng)格繪制圖形球體

    unity通過Mesh網(wǎng)格繪制圖形球體

    這篇文章主要為大家詳細介紹了unity通過Mesh網(wǎng)格繪制圖形球體,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C# OpenVINO讀取百度模型實現(xiàn)印章檢測

    C# OpenVINO讀取百度模型實現(xiàn)印章檢測

    這篇文章主要為大家詳細介紹了C# OpenVINO如何通過直接讀取百度模型實現(xiàn)印章檢測,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-12-12
  • C#操作windows注冊表的方法

    C#操作windows注冊表的方法

    這篇文章主要介紹了C#操作windows注冊表的方法,涉及C#針對注冊表的讀取與寫入技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04

最新評論