婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Html5通過數(shù)據(jù)流方式播放視頻的實現(xiàn)

Html5通過數(shù)據(jù)流方式播放視頻的實現(xiàn)

熱門標(biāo)簽:高德地圖標(biāo)注廁所 西安金倫外呼系統(tǒng) 江西ai電銷機(jī)器人如何 中國地圖標(biāo)注城市的 威海語音外呼系統(tǒng)平臺 地圖標(biāo)注員工作內(nèi)容 通遼地圖標(biāo)注app 智能語音電銷機(jī)器人客戶端 地圖標(biāo)注沿海城市房價

本文介紹如何通過H5頁面通過數(shù)據(jù)流的方式播放服務(wù)端的視頻文件,可以兼容PC、Android和IOS環(huán)境。

H5頁面可以通過<video> 標(biāo)簽來播放視頻。一般的方式如下:

<!DOCTYPE HTML>
<html>
<body>

<video src="/i/movie.mp4" controls="controls">
your browser does not support the video tag
</video>

</body>
</html>

src中指定了要播放的視頻的URL,為具體的視頻文件路徑。當(dāng)將訪問請求變?yōu)間etVideo.do?fileId=xxx 這種形式,服務(wù)端返回字節(jié)流的時候后端實現(xiàn)需要一些更改。

一般的方式是讀本地文件然后寫到response中,代碼實現(xiàn)如下:

public void downFile(File downloadFile, 
      HttpServletResponse response, 
      HttpServletRequest request) throws Exception {
 response.reset();
 response.setContentType("video/mp4;charset=UTF-8"); 
 
 InputStream in = null;
 ServletOutputStream out = null;
 try { 
  out = response.getOutputStream();
  
  in = new FileInputStream(downloadFile);
  if(in !=null){
    byte[] b = new byte[1024];  
     int i = 0;  
     while((i = in.read(b)) > 0){  
    out.write(b, 0, i);  
     }  
     out.flush();   
     in.close(); 
   
  }
 } catch (Exception e) {
  
   e.printStackTrace();
 
 }finally{
  if(in != null) {  
   try { in.close(); } catch (IOException e) { }  
   in = null;  
  } 
  if(out != null) {  
   try { out.close(); } catch (IOException e) { }  
   out = null;  
  } 
 }
}

這種方式在PC端和Android手機(jī)上都能正常顯示,但在IOS手機(jī)上通過Safari瀏覽器就不能播放。ios目前獲取視頻的時候請求頭會帶一個與斷點續(xù)傳有關(guān)的信息。對于ios來說,他不是一次性請求全部文件的,一般首先會請求0-1字節(jié),這個會寫在request header的"range"字段中:range:‘bytes=0-1’。
而服務(wù)端必須滿足range的要求:解析range字段,然后按照range字段的要求返回對應(yīng)的數(shù)據(jù)。

在響應(yīng)頭中response header至少要包含三個字段:

  • Content-Type:明確指定視頻格式,有"video/mp4", “video/ogg”, "video/mov"等等。
  • Content-Range:格式是 “bytes <start>-<end>/<total>”,其中start和end必需對應(yīng)request header里的range字段,total是文件總大小。
  • Content-Length:返回的二進(jìn)制長度。

斷點續(xù)傳實現(xiàn)如下:

public void downRangeFile(File downloadFile, 
       HttpServletResponse response, 
       HttpServletRequest request) throws Exception {

 if (!downloadFile.exists()) {
  response.sendError(HttpServletResponse.SC_NOT_FOUND);
  return;
 }

 long fileLength = downloadFile.length();// 記錄文件大小  
 long pastLength = 0;// 記錄已下載文件大小  
 int rangeSwitch = 0;// 0:從頭開始的全文下載;1:從某字節(jié)開始的下載(bytes=27000-);2:從某字節(jié)開始到某字節(jié)結(jié)束的下載(bytes=27000-39000)  
 long contentLength = 0;// 客戶端請求的字節(jié)總量  
 String rangeBytes = "";// 記錄客戶端傳來的形如“bytes=27000-”或者“bytes=27000-39000”的內(nèi)容  
 RandomAccessFile raf = null;// 負(fù)責(zé)讀取數(shù)據(jù)  
 OutputStream os = null;// 寫出數(shù)據(jù)  
 OutputStream out = null;// 緩沖  
 int bsize = 1024;// 緩沖區(qū)大小  
 byte b[] = new byte[bsize];// 暫存容器  

 String range = request.getHeader("Range");
 int responseStatus = 206;
 if (range != null && range.trim().length() > 0 && !"null".equals(range)) {// 客戶端請求的下載的文件塊的開始字節(jié)  
  responseStatus = javax.servlet.http.HttpServletResponse.SC_PARTIAL_CONTENT;
  System.out.println("request.getHeader(\&;Range\&;)=" + range);
  rangeBytes = range.replaceAll("bytes=", "");
  if (rangeBytes.endsWith("-")) {
   rangeSwitch = 1;
   rangeBytes = rangeBytes.substring(0, rangeBytes.indexOf('-'));
   pastLength = Long.parseLong(rangeBytes.trim());
   contentLength = fileLength - pastLength;
  } else {
   rangeSwitch = 2;
   String temp0 = rangeBytes.substring(0, rangeBytes.indexOf('-'));
   String temp2 = rangeBytes.substring(rangeBytes.indexOf('-') + 1, rangeBytes.length());
   pastLength = Long.parseLong(temp0.trim());
  }
 } else {
  contentLength = fileLength;// 客戶端要求全文下載  
 }

 
 // 清除首部的空白行  
 response.reset();
 // 告訴客戶端允許斷點續(xù)傳多線程連接下載,響應(yīng)的格式是:Accept-Ranges: bytes  
 response.setHeader("Accept-Ranges", "bytes");
 // 如果是第一次下,還沒有斷點續(xù)傳,狀態(tài)是默認(rèn)的 200,無需顯式設(shè)置;響應(yīng)的格式是:HTTP/1.1  

 if (rangeSwitch != 0) {
  response.setStatus(responseStatus);
  // 不是從最開始下載,斷點下載響應(yīng)號為206  
  // 響應(yīng)的格式是:  
  // Content-Range: bytes [文件塊的開始字節(jié)]-[文件的總大小 - 1]/[文件的總大小]  
  switch (rangeSwitch) {
   case 1: {
    String contentRange = new StringBuffer("bytes ")
      .append(new Long(pastLength).toString()).append("-")
      .append(new Long(fileLength - 1).toString())
      .append("/").append(new Long(fileLength).toString())
      .toString();
    response.setHeader("Content-Range", contentRange);
    break;
   }
   case 2: {
    String contentRange = range.replace("=", " ") + "/"
      + new Long(fileLength).toString();
    response.setHeader("Content-Range", contentRange);
    break;
   }
   default: {
    break;
   }
  }
 } else {
  String contentRange = new StringBuffer("bytes ").append("0-")
    .append(fileLength - 1).append("/").append(fileLength)
    .toString();
  response.setHeader("Content-Range", contentRange);
 }

 try {
  response.setContentType("video/mp4;charset=UTF-8"); 
  response.setHeader("Content-Length", String.valueOf(contentLength));
  os = response.getOutputStream();
  out = new BufferedOutputStream(os);
  raf = new RandomAccessFile(downloadFile, "r");
  try {
   long outLength = 0;// 實際輸出字節(jié)數(shù)  
   switch (rangeSwitch) {
    case 0: {
    }
    case 1: {
     raf.seek(pastLength);
     int n = 0;
     while ((n = raf.read(b)) != -1) {
      out.write(b, 0, n);
      outLength += n;
     }
     break;
    }
    case 2: {
     raf.seek(pastLength);
     int n = 0;
     long readLength = 0;// 記錄已讀字節(jié)數(shù)  
     while (readLength <= contentLength - bsize) {// 大部分字節(jié)在這里讀取  
      n = raf.read(b);
      readLength += n;
      out.write(b, 0, n);
      outLength += n;
     }
     if (readLength <= contentLength) {// 余下的不足 1024 個字節(jié)在這里讀取  
      n = raf.read(b, 0, (int) (contentLength - readLength));
      out.write(b, 0, n);
      outLength += n;
     }
     break;
    }
    default: {
     break;
    }
   }
   System.out.println("Content-Length為:" + contentLength + ";實際輸出字節(jié)數(shù):" + outLength);
   out.flush();
  } catch (IOException ie) {
   // ignore  
  }
 } catch (Exception e) {
  e.printStackTrace();
 } finally {
  if (out != null) {
   try {
    out.close();
   } catch (IOException e) {
    e.printStackTrace();
   }
  }
  if (raf != null) {
   try {
    raf.close();
   } catch (IOException e) {
    e.printStackTrace();
   }
  }
 }
}

H5頁面:

<!DOCTYPE HTML>
<html>
<body>


<video width="100%" height="200" rel="preload" x5-video-player-type="h5" playsinline="true" webkit-playsinline="true" controls="controls">
<source src="http://127.0.0.1:8080/XXX/getVideo.do?fileId=16" type="video/mp4">
</video>

</script>
</body>
</html>

通過上述斷點續(xù)傳方式H5可正常播放視頻數(shù)據(jù)流,并且支持各種平臺。

到此這篇關(guān)于Html5通過數(shù)據(jù)流方式播放視頻的實現(xiàn)的文章就介紹到這了,更多相關(guān)Html5數(shù)據(jù)流播放視頻內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

標(biāo)簽:晉中 河池 北海 眉山 阜陽 崇左 營口 青海

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Html5通過數(shù)據(jù)流方式播放視頻的實現(xiàn)》,本文關(guān)鍵詞  Html5,通過,數(shù)據(jù)流,方式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Html5通過數(shù)據(jù)流方式播放視頻的實現(xiàn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Html5通過數(shù)據(jù)流方式播放視頻的實現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    中文字幕一区二区三区在线观看 | 中文字幕av不卡| 91亚洲精品久久久蜜桃网站| 免费成人深夜小野草| 亚洲www啪成人一区二区麻豆| 亚洲视频每日更新| 一区二区欧美精品| 首页综合国产亚洲丝袜| 久久国产精品色婷婷| 蜜臀91精品一区二区三区| 久久精品久久99精品久久| 精品一区二区免费在线观看| 国产美女精品在线| 成人app在线观看| 欧美影院精品一区| 欧美电影在线免费观看| 亚洲精品在线免费播放| 日本一区二区在线不卡| 有码一区二区三区| 日韩和的一区二区| 国产v日产∨综合v精品视频| 99久久久无码国产精品| 欧美丰满一区二区免费视频| 久久亚洲欧美国产精品乐播| 亚洲欧洲99久久| 亚洲成人动漫在线免费观看| 精品亚洲免费视频| 波波电影院一区二区三区| 欧美三电影在线| 久久久久久久综合色一本| 亚洲丝袜另类动漫二区| 青青青伊人色综合久久| 成人黄色777网| 欧美日韩精品一二三区| 中文字幕高清一区| 午夜精品久久久久久久99水蜜桃 | 日韩午夜激情av| 久久久久免费观看| 亚洲图片自拍偷拍| 国产麻豆精品95视频| 欧美亚洲日本国产| 国产欧美一区视频| 日韩1区2区3区| 91丝袜高跟美女视频| 日韩精品资源二区在线| 亚洲一区二区三区三| 国产精品69毛片高清亚洲| 欧美日本一区二区| 亚洲色欲色欲www在线观看| 激情六月婷婷久久| 欧美精品 日韩| 亚洲欧美日韩一区二区三区在线观看| 另类中文字幕网| 欧美色图片你懂的| 亚洲裸体xxx| 97精品电影院| 中文字幕的久久| 国产一区二区影院| 91精品国产乱码久久蜜臀| 一区二区三区四区激情 | 欧美精品一卡二卡| 一区二区三区视频在线观看| 97久久精品人人做人人爽50路| 精品国产精品网麻豆系列 | 亚洲一区二区三区中文字幕在线| 国产传媒一区在线| 久久久精品国产免费观看同学| 丝袜美腿一区二区三区| 欧美日本一区二区| 日韩综合在线视频| 91麻豆精品国产91久久久更新时间| 亚洲午夜久久久| 欧美日韩在线亚洲一区蜜芽| 亚洲一区二区三区国产| 精品视频一区 二区 三区| 亚洲综合图片区| 欧美精品18+| 精品一区二区综合| 久久这里都是精品| 国产河南妇女毛片精品久久久| 国产欧美一区二区三区沐欲| 成人免费看片app下载| 韩国精品在线观看| 国产精品乱码久久久久久| 99国产精品国产精品久久| 亚洲精品综合在线| 欧美丰满一区二区免费视频| 精品中文字幕一区二区小辣椒| wwwwww.欧美系列| www.欧美亚洲| 亚洲成人av资源| 日韩欧美国产电影| 不卡电影免费在线播放一区| 国产精品的网站| 色天使久久综合网天天| 丝袜美腿亚洲一区二区图片| 欧美成人性福生活免费看| 国产成人av影院| 国产精品久久久久久久第一福利| 色综合亚洲欧洲| 亚洲va国产va欧美va观看| 26uuuu精品一区二区| 99久久久无码国产精品| 天天综合天天综合色| 久久一区二区视频| 99麻豆久久久国产精品免费| 五月天亚洲精品| 欧美激情一区二区三区四区| 欧美日韩在线免费视频| 国产一区二区三区在线观看精品| 亚洲女同女同女同女同女同69| 日韩一区二区三区四区五区六区| 大陆成人av片| 日韩福利视频导航| 国产精品毛片无遮挡高清| 欧美日韩精品欧美日韩精品一| 狠狠色丁香久久婷婷综合丁香| 自拍偷自拍亚洲精品播放| 欧美日本一区二区三区四区| 粉嫩高潮美女一区二区三区| 日韩国产高清在线| 中文字幕亚洲一区二区va在线| 欧美日韩亚洲综合在线| 东方欧美亚洲色图在线| 日韩av电影免费观看高清完整版在线观看 | 日韩欧美激情一区| 色婷婷综合久久| 狠狠色丁香九九婷婷综合五月| 亚洲综合精品自拍| 亚洲天堂网中文字| www国产亚洲精品久久麻豆| 欧美日韩美少妇| 91最新地址在线播放| 国产成人在线影院| 日韩不卡一二三区| 天天操天天干天天综合网| 依依成人精品视频| 亚洲欧美偷拍三级| 亚洲欧美自拍偷拍| 国产精品素人视频| 国产精品视频在线看| 日本一区二区在线不卡| 国产香蕉久久精品综合网| 日韩久久免费av| 精品嫩草影院久久| 精品国产99国产精品| 亚洲精品一线二线三线| 精品国产乱子伦一区| 精品久久久久香蕉网| 精品91自产拍在线观看一区| 精品国产电影一区二区| 久久久久久综合| 国产精品久久久久久久第一福利| ...xxx性欧美| 一区二区在线观看免费视频播放| 亚洲激情第一区| 亚洲成精国产精品女| 午夜av电影一区| 美女精品一区二区| 国产一区二区三区在线观看免费视频| 蜜臀av一区二区| 国产精选一区二区三区| 夫妻av一区二区| 色又黄又爽网站www久久| 欧美少妇xxx| 欧美精品一区二区三区在线| 亚洲国产精品二十页| 亚洲精选在线视频| 奇米777欧美一区二区| 激情偷乱视频一区二区三区| 国产成人鲁色资源国产91色综| 国产精品一区二区久久精品爱涩 | 自拍偷在线精品自拍偷无码专区| 亚洲丝袜美腿综合| 日韩中文字幕亚洲一区二区va在线| 久久99国产精品免费| av电影在线不卡| 91精品国产综合久久久蜜臀粉嫩| www日韩大片| 一级特黄大欧美久久久| 日日摸夜夜添夜夜添精品视频| 日韩黄色片在线观看| www..com久久爱| 欧美一区二视频| 亚洲女人的天堂| 国模无码大尺度一区二区三区| 一本到高清视频免费精品| 欧美久久久一区| ...xxx性欧美| 国产成人在线影院| 欧美精品一二三四| 亚洲丝袜自拍清纯另类| 国产一区在线精品| 欧美精品色综合| 亚洲毛片av在线| 99久久久久久99| 国产欧美精品一区| 乱中年女人伦av一区二区| 91久久线看在观草草青青| 日本一区二区三区四区|