ASP下通過(guò)Adodb.Stream實(shí)現(xiàn)多線程下載大文件
有個(gè)朋友 做 某種小眾音樂(lè)交換站的(他們那個(gè)行業(yè)的昵圖網(wǎng)),需要用到付費(fèi)下載。嘗試過(guò) 防盜鏈,不太理想,最終使用了 Adodb.Stream 讀取,直接輸出。
解決了 盜版的問(wèn)題,但是新的問(wèn)題又來(lái)了。Adodb.Stream 這種方式 電腦還好說(shuō),大部分電腦瀏覽器都支持。移動(dòng)端 很多 瀏覽器為了 加速讀取,會(huì)多線程下載導(dǎo)致 文件無(wú)法正常讀取。
抓包,發(fā)現(xiàn)增加了 HTTP頭 HTTP_RANGE。隱約記得 之前讀過(guò) 王大(王洪影)的 《深入解析 ASP核心技術(shù)》當(dāng)中提到ASP多線程下載的問(wèn)題,回家翻出來(lái),最終還就真解決了。
為了 方便調(diào)用,直接寫成了 一個(gè) 函數(shù)。沒(méi)用王大的代碼,感覺(jué)我自己的更美(自戀中…)。如有有需要的朋友需要,直接拿走即可,代碼如下:
option explicit 'inputFile 需要下載的文件 'outputName 輸出文件名,可以為空,為空時(shí)自動(dòng)根據(jù) inputFile 生成 Sub CreateDownloader(byval inputFile, byval outputName) Dim filePath filePath = Server.Mappath(inputFile) If outputName = "" Then outputName = Split(filePath, "\")(UBound(Split(filePath, "\"))) '下載開(kāi)始 Dim AdoStream, bufferSize Set AdoStream = Server.CreateObject("Adodb.Stream") 'Adodb.Stream,實(shí)例變量名為了方便區(qū)分用大寫 bufferSize = 2 * 1024 * 1024 '每次讀取大小(byte) 2M AdoStream.Mode = 3 '1 讀,2 寫,3 讀寫 AdoStream.Type = 1 '1 二進(jìn)制,2 文本 AdoStream.Open AdoStream.LoadFromFile(filePath) '載入文件 Response.AddHeader "Content-Disposition", "attachment; filename=" & outputName '文件名 Response.ContentType = "application/octet-stream" '通知瀏覽器接受的文件類型(可自己定義,很多種,但一般都用這個(gè) Dim httpRange,rangeStart,fileSize '獲取 分段下載 請(qǐng)求 httpRange = Request.ServerVariables("HTTP_RANGE") fileSize = AdoStream.size '文件總大小 If httpRange = "" Then '不支持?jǐn)帱c(diǎn)續(xù)傳 rangeStart = 0 Else '支持?jǐn)帱c(diǎn)續(xù)傳 httpRange = Mid(httpRange, 7) rangeStart = CLng(Split(httpRange, "-")(0)) If rangeStart < 0 Or rangeStart >= fileSize Then '已經(jīng)下載完畢 Response.Status = "416 Requested range not satisfiable" Else Response.Status = "206 Partial Content" Response.AddHeader "Content-Range", "bytes " & rangeStart & "-" & (fileSize - 1) & "/" & fileSize AdoStream.Position = rangeStart End If End If Dim binaryBlock If Response.Status <> "416 Requested range not satisfiable" Then Response.AddHeader "Content-Length", fileSize - rangeStart '通知瀏覽器接收的文件大小 binaryBlock = AdoStream.Read(bufferSize) Do While Lenb(binaryBlock) > 0 '循環(huán)讀取直到讀完為止 Response.BinaryWrite binaryBlock '輸出二進(jìn)制數(shù)據(jù)流 Response.Flush '立即發(fā)送(要求至少256字節(jié)),不加的話可能提示超過(guò)緩存區(qū)。 binaryBlock = AdoStream.Read(bufferSize) Loop End If AdoStream.Close '關(guān)閉文件對(duì)象 Set AdoStream = Nothing Response.End End Sub
使用也非常簡(jiǎn)單,假如上面的代碼保存到了 downloader.asp,直接引用即可:
<!--#include file="downloader.asp"--> <% '創(chuàng)建下載 call CreateDownloader("down/tools.rar", "") '創(chuàng)建下載并自定義文件名 call CreateDownloader("down/tools.rar", "hello.rar") %>
有圖有真相:
到此這篇關(guān)于ASP下通過(guò)Adodb.Stream實(shí)現(xiàn)多線程下載大文件的文章就介紹到這了,更多相關(guān)ASP多線程下載大文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP中if語(yǔ)句、select 、while循環(huán)的使用方法
這篇文章主要介紹了ASP中if語(yǔ)句、select 、while循環(huán)的使用方法,需要的朋友可以參考下2015-11-11access數(shù)據(jù)庫(kù)的一些少用操作,ASP,創(chuàng)建數(shù)據(jù)庫(kù)文件,創(chuàng)建表,創(chuàng)建字段,ADOX
access數(shù)據(jù)庫(kù)的一些少用操作,ASP,創(chuàng)建數(shù)據(jù)庫(kù)文件,創(chuàng)建表,創(chuàng)建字段,ADOX...2006-10-10msxml3.dll 錯(cuò)誤 800c0019 系統(tǒng)錯(cuò)誤:-2146697191解決方法
今天發(fā)現(xiàn)一個(gè)asp后臺(tái)使用了XMLHTTP組件的頁(yè)面無(wú)法無(wú)法生成靜態(tài)頁(yè)面了,運(yùn)行時(shí)提示msxml3.dll 錯(cuò)誤 800c0019 系統(tǒng)錯(cuò)誤:-2146697191,經(jīng)過(guò)搜索如下方法解決了問(wèn)題2020-11-11Js獲取asp頁(yè)面返回的值(加載值)實(shí)現(xiàn)代碼
本文詳細(xì)介紹Js獲取asp頁(yè)面返回的值(加載值)實(shí)現(xiàn)方法,需要了解的朋友可以參考下2012-12-12asp下利用fso實(shí)現(xiàn)文件夾或文件移動(dòng)改名等操作函數(shù)
以后利用fso來(lái)操作文件和文件夾就方便了2008-01-01