摘要:比如這個在線視頻我們可以正常播放,但是找不到下載按鈕。因此,這個在線視頻被拆分成了若干多的小片段,然后通過瀏覽器下載到本地進行播放。使用自帶的多線程庫多線程下載這些片段。第行可以指定線程池里工作線程的個數。
比如這個在線視頻:
我們可以正常播放,但是找不到下載按鈕。
打開Chrome開發者工具,在Network標簽頁里能看到很多網絡傳輸請求:
隨便看一個請求的響應,發現類型為video,大小為500多k。因此,這個在線視頻被拆分成了若干500多k的小片段,然后通過瀏覽器下載到本地進行播放。
這個片段的url:
http://d2vvqvds83fsd.cloudfro...:event/18/36/06/3/rt/1/resources/180919_PID_Intelligent_Enterprise_Gruenewald_720p-5F92.smil/media_b433000_10.ts
那么這個片段一共有多少個片段呢?在所有片段開始下載之前,有這樣一個請求:chunklist即是視頻片段的清單。
通過這個清單我們知道這個視頻一共分為55個片段,序號從0開始。
了解了原理,我們就可以開始編程了。
1. 首先實現視頻片段的下載邏輯,新建一個類,實現Runnable接口。
2. 使用JDK自帶的多線程庫 ExecutorService多線程下載這些片段。ExecutorService實際是一個線程池。第15行可以指定線程池里工作線程(Working thread)的個數。
private void download(){ URL task = null; String path = DownloadLauncher.LOCALPATH + this.mIndex + DownloadLauncher.POSTFIX; String url = this.mTask; try { task = new URL(url); DataInputStream dataInputStream = new DataInputStream(task.openStream()); FileOutputStream fileOutputStream = new FileOutputStream(new File(path)); ByteArrayOutputStream output = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int length; while ((length = dataInputStream.read(buffer)) > 0) { output.write(buffer, 0, length); } fileOutputStream.write(output.toByteArray()); dataInputStream.close(); fileOutputStream.close(); System.out.println("File: " + this.mIndex + " downloaded ok"); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } }
下載完成后,能在Eclipse的console控制臺看到這些輸出:
下載成功的視頻片段:
3. Merger負責把這些片段合并成一個大文件。
private static void run() throws IOException{ FileInputStream in = null; String destFile = DownloadLauncher.LOCALPATH + DownloadLauncher.MERGED; FileOutputStream out = new FileOutputStream(destFile,true); for( int i = 0; i <= DownloadLauncher.LAST; i++){ byte[] buf = new byte[1024]; int len = 0; String sourceFile = DownloadLauncher.LOCALPATH + i + DownloadLauncher.POSTFIX; in = new FileInputStream(sourceFile); while( (len = in.read(buf)) != -1 ){ out.write(buf,0,len); } } out.close(); } public static void main(String[] args) { try { run(); } catch (IOException e) { e.printStackTrace(); } System.out.println("Merged ok!"); }
完整的代碼在我的github上:
https://github.com/i042416/Ja...
要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/71920.html
摘要:比如這個在線視頻我們可以正常播放,但是找不到下載按鈕。因此,這個在線視頻被拆分成了若干多的小片段,然后通過瀏覽器下載到本地進行播放。使用自帶的多線程庫多線程下載這些片段。第行可以指定線程池里工作線程的個數。 比如這個在線視頻: showImg(https://segmentfault.com/img/remote/1460000016829926); 我們可以正常播放,但是找不到下載按...
摘要:能理解線程模型多線程優缺點以及如何避免。多線程的出現主要是為了提高的利用率任務的執行效率。所以要考慮清楚是否真的需要多線程。這一塊的內容可以然我們知道寫大牛處理并發的思路,對我們自己編寫高質量的多線程程序也有很多幫助。 showImg(https://segmentfault.com/img/remote/1460000015980196?w=2048&h=1363); 前言 已經記不...
閱讀 2097·2021-11-24 09:39
閱讀 1564·2021-10-11 10:59
閱讀 2509·2021-09-24 10:28
閱讀 3383·2021-09-08 09:45
閱讀 1275·2021-09-07 10:06
閱讀 1673·2019-08-30 15:53
閱讀 2068·2019-08-30 15:53
閱讀 1427·2019-08-30 15:53