国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

自己開發的在線視頻下載工具,基于Java多線程

jsummer / 3982人閱讀

摘要:比如這個在線視頻我們可以正常播放,但是找不到下載按鈕。因此,這個在線視頻被拆分成了若干多的小片段,然后通過瀏覽器下載到本地進行播放。使用自帶的多線程庫多線程下載這些片段。第行可以指定線程池里工作線程的個數。

比如這個在線視頻:

我們可以正常播放,但是找不到下載按鈕。

打開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://specialneedsforspecialkids.com/yun/11067.html

相關文章

  • 自己開發在線視頻下載工具基于Java線程

    摘要:比如這個在線視頻我們可以正常播放,但是找不到下載按鈕。因此,這個在線視頻被拆分成了若干多的小片段,然后通過瀏覽器下載到本地進行播放。使用自帶的多線程庫多線程下載這些片段。第行可以指定線程池里工作線程的個數。 比如這個在線視頻: showImg(https://segmentfault.com/img/remote/1460000016829926); 我們可以正常播放,但是找不到下載按...

    Blackjun 評論0 收藏0
  • 如何成為一位「不那么差」程序員

    摘要:能理解線程模型多線程優缺點以及如何避免。多線程的出現主要是為了提高的利用率任務的執行效率。所以要考慮清楚是否真的需要多線程。這一塊的內容可以然我們知道寫大牛處理并發的思路,對我們自己編寫高質量的多線程程序也有很多幫助。 showImg(https://segmentfault.com/img/remote/1460000015980196?w=2048&h=1363); 前言 已經記不...

    caspar 評論0 收藏0

發表評論

0條評論

jsummer

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<