亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > Html5通過數據流方式播放視頻的實現

Html5通過數據流方式播放視頻的實現

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

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

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

<!DOCTYPE HTML>
<html>
<body>

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

</body>
</html>

src中指定了要播放的視頻的URL,為具體的視頻文件路徑。當將訪問請求變為getVideo.do?fileId=xxx 這種形式,服務端返回字節流的時候后端實現需要一些更改。

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

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手機上都能正常顯示,但在IOS手機上通過Safari瀏覽器就不能播放。ios目前獲取視頻的時候請求頭會帶一個與斷點續傳有關的信息。對于ios來說,他不是一次性請求全部文件的,一般首先會請求0-1字節,這個會寫在request header的"range"字段中:range:‘bytes=0-1’。
而服務端必須滿足range的要求:解析range字段,然后按照range字段的要求返回對應的數據。

在響應頭中response header至少要包含三個字段:

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

斷點續傳實現如下:

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:從某字節開始的下載(bytes=27000-);2:從某字節開始到某字節結束的下載(bytes=27000-39000)  
 long contentLength = 0;// 客戶端請求的字節總量  
 String rangeBytes = "";// 記錄客戶端傳來的形如“bytes=27000-”或者“bytes=27000-39000”的內容  
 RandomAccessFile raf = null;// 負責讀取數據  
 OutputStream os = null;// 寫出數據  
 OutputStream out = null;// 緩沖  
 int bsize = 1024;// 緩沖區大小  
 byte b[] = new byte[bsize];// 暫存容器  

 String range = request.getHeader("Range");
 int responseStatus = 206;
 if (range != null && range.trim().length() > 0 && !"null".equals(range)) {// 客戶端請求的下載的文件塊的開始字節  
  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();
 // 告訴客戶端允許斷點續傳多線程連接下載,響應的格式是:Accept-Ranges: bytes  
 response.setHeader("Accept-Ranges", "bytes");
 // 如果是第一次下,還沒有斷點續傳,狀態是默認的 200,無需顯式設置;響應的格式是:HTTP/1.1  

 if (rangeSwitch != 0) {
  response.setStatus(responseStatus);
  // 不是從最開始下載,斷點下載響應號為206  
  // 響應的格式是:  
  // Content-Range: bytes [文件塊的開始字節]-[文件的總大小 - 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;// 實際輸出字節數  
   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;// 記錄已讀字節數  
     while (readLength <= contentLength - bsize) {// 大部分字節在這里讀取  
      n = raf.read(b);
      readLength += n;
      out.write(b, 0, n);
      outLength += n;
     }
     if (readLength <= contentLength) {// 余下的不足 1024 個字節在這里讀取  
      n = raf.read(b, 0, (int) (contentLength - readLength));
      out.write(b, 0, n);
      outLength += n;
     }
     break;
    }
    default: {
     break;
    }
   }
   System.out.println("Content-Length為:" + contentLength + ";實際輸出字節數:" + 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>

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

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

標簽:晉中 河池 北海 眉山 阜陽 崇左 營口 青海

巨人網絡通訊聲明:本文標題《Html5通過數據流方式播放視頻的實現》,本文關鍵詞  Html5,通過,數據流,方式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Html5通過數據流方式播放視頻的實現》相關的同類信息!
  • 本頁收集關于Html5通過數據流方式播放視頻的實現的相關信息資訊供網民參考!
  • 推薦文章
    午夜久久网| 青青久久精品国产免费看| 韩国三级香港三级日本三级la| 欧美另类videosbestsex视频| 国产网站免费在线观看| 日本免费看视频| 九九精品在线播放| 久草免费资源| 国产亚洲男人的天堂在线观看| 精品视频在线观看一区二区 | 国产高清视频免费观看| 九九久久国产精品| 99久久精品费精品国产一区二区| 韩国毛片免费| 欧美激情一区二区三区视频 | 美女免费毛片| 国产伦久视频免费观看 视频 | 亚洲天堂在线播放| 一级毛片视频播放| 成人高清护士在线播放| 九九干| 国产一级强片在线观看| 黄视频网站在线看| 精品美女| 欧美激情一区二区三区在线| 欧美国产日韩精品| 一级女性全黄久久生活片| 国产精品免费久久| 亚洲天堂一区二区三区四区| 国产视频一区二区在线观看| 99热热久久| 欧美电影免费看大全| 免费毛片播放| a级黄色毛片免费播放视频| 九九精品久久久久久久久| 午夜久久网| 成人影院久久久久久影院| 午夜激情视频在线观看| 午夜在线亚洲男人午在线| 亚洲 欧美 91| 免费一级片在线观看| 成人a大片高清在线观看| 青青青草影院 | 成人免费网站视频ww| 日韩中文字幕在线亚洲一区| 黄色短视屏| 色综合久久天天综合观看| 一级片片| 久久国产精品自由自在| 91麻豆精品国产综合久久久| 国产一区二区高清视频| 97视频免费在线| 国产91丝袜在线播放0| 午夜在线亚洲男人午在线| 青草国产在线观看| 夜夜操网| 色综合久久天天综线观看| 国产a免费观看| 你懂的日韩| 国产伦精品一区二区三区在线观看| 国产不卡在线播放| 精品久久久久久免费影院| 黄视频网站在线观看| 成人高清免费| 一级女人毛片人一女人| 欧美1卡一卡二卡三新区| 国产精品自拍一区| 亚欧成人毛片一区二区三区四区| 亚洲精品永久一区| 九九国产| 精品国产一区二区三区久久久狼 | 亚洲精品影院| 可以在线看黄的网站| 日本在线www| 国产美女在线观看| 国产不卡在线看| 国产麻豆精品hdvideoss| 日本免费乱理伦片在线观看2018| 精品视频在线观看一区二区三区| 999精品视频在线| 天堂网中文字幕| 精品久久久久久中文| 国产91精品一区| 一级毛片视频播放| 国产成人精品一区二区视频| 国产高清在线精品一区二区| 欧美国产日韩一区二区三区| 欧美电影免费| 黄视频网站在线观看| 四虎影视库| 国产高清在线精品一区二区 | 九九九在线视频| 欧美a免费| 亚久久伊人精品青青草原2020| 你懂的在线观看视频| 国产欧美精品| 国产一区二区精品| 天天做人人爱夜夜爽2020| 国产一区二区精品尤物| 欧美日本韩国| 欧美日本韩国| 高清一级片| 麻豆系列国产剧在线观看| 亚洲第一视频在线播放| 欧美1卡一卡二卡三新区| 尤物视频网站在线| 中文字幕一区二区三区 精品| 精品视频免费观看| 九九九国产| 国产91素人搭讪系列天堂| 国产伦精品一区二区三区在线观看| 国产不卡在线看| 精品视频免费观看| 国产a免费观看| 欧美一级视| 免费国产在线视频| 99色视频在线观看| 99久久网站| 亚洲女人国产香蕉久久精品| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 97视频免费在线观看| 久草免费在线色站| 精品视频免费看| 999久久久免费精品国产牛牛| 成人免费一级毛片在线播放视频| 91麻豆国产| 久久精品成人一区二区三区| 欧美日本韩国| 精品视频在线观看一区二区| 精品视频在线观看视频免费视频| 成人免费网站久久久| 欧美大片毛片aaa免费看| 日日夜夜婷婷| 91麻豆精品国产自产在线观看一区| 台湾美女古装一级毛片| 亚洲 男人 天堂| 国产激情视频在线观看| 精品在线视频播放| 国产不卡高清在线观看视频| a级黄色毛片免费播放视频| 久久成人性色生活片| 亚洲精品中文字幕久久久久久| 亚洲 男人 天堂| 久久精品成人一区二区三区| 999久久久免费精品国产牛牛| 欧美大片毛片aaa免费看| 美女免费精品视频在线观看| 亚洲爆爽| 午夜激情视频在线播放| 国产国产人免费视频成69堂| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美a级大片| 日韩专区第一页| 青青青草影院| 99色吧| 91麻豆精品国产自产在线观看一区 | 国产成人精品影视| 精品国产亚一区二区三区| 久久99中文字幕| 一级女人毛片人一女人| 台湾美女古装一级毛片| 国产91精品一区| a级毛片免费全部播放| 99热精品一区| 国产成人女人在线视频观看| 91麻豆国产福利精品| 欧美大片毛片aaa免费看| 亚洲天堂免费观看| 亚洲 男人 天堂| 香蕉视频亚洲一级| 久久99青青久久99久久| 亚洲精品影院| 国产伦精品一区三区视频 | 日韩免费片| 青青青草影院| 午夜欧美福利| 日本在线不卡免费视频一区| 麻豆午夜视频| 天天色色网| 欧美激情一区二区三区视频| 你懂的在线观看视频| 久久国产影院| 精品在线免费播放| 国产视频久久久| 国产不卡在线观看| 九九九在线视频| 91麻豆精品国产自产在线观看一区| 精品国产一区二区三区久久久狼| 国产成a人片在线观看视频| 日本免费看视频| 色综合久久久久综合体桃花网| 日本免费区| 人人干人人插| 麻豆网站在线免费观看| 日本在线不卡视频| 美女免费毛片| 国产精品自拍在线观看| 国产美女在线一区二区三区| 可以免费看毛片的网站| 91麻豆精品国产高清在线|