青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

http協議 文件下載原理詳解

Posted on 2009-09-13 12:42 S.l.e!ep.¢% 閱讀(4528) 評論(0)  編輯 收藏 引用 所屬分類: NetWork
http協議 文件下載原理詳解
2009年06月01日 星期一 04:53 P.M.

最近研究了一下關于文件下載的相關內容,覺得還是寫些東西記下來比較好。起初只是想研究研究,但后來發現寫個可重用性比較高的模塊還是很有必要的,我想這也是大多數開發人員的習慣吧。
對于HTTP協議,向服務器請求某個文件時,只要發送類似如下的請求即可:

GET /Path/FileName HTTP/1.0
Host: www.server.com:80
Accept: */*
User-Agent: GeneralDownloadApplication
Connection: close

每行用一個“回車換行”分隔,末尾再追加一個“回車換行”作為整個請求的結束。

第一行中的GET是HTTP協議支持的方法之一,方法名是大小寫敏感的,HTTP協議還支持OPTIONS、HAED、POST、PUT、DELETE、TRACE、CONNECT等方法,而GET和HEAD這兩個方法通常被認為是“安全的”,也就是說任何實現了HTTP協議的服務器程序都會實現這兩個方法。對于文件下載功能,GET足矣。GET后面是一個空格,其后緊跟的是要下載的文件從WEB服務器根開始的絕對路徑。該路徑后又有一個空格,然后是協議名稱及協議版本。

除第一行以外,其余行都是HTTP頭的字段部分。Host字段表示主機名和端口號,如果端口號是默認的80則可以不寫。Accept字段中的*/*表示接收任何類型的數據。User-Agent表示用戶代理,這個字段可有可無,但強烈建議加上,因為它是服務器統計、追蹤以及識別客戶端的依據。Connection字段中的close表示使用非持久連接。

關于HTTP協議更多的細節可以參考RFC2616(HTTP 1.1)。因為我只是想通過HTTP協議實現文件下載,所以也只看了一部分,并沒有看全。

如果服務器成功收到該請求,并且沒有出現任何錯誤,則會返回類似下面的數據:

HTTP/1.0 200 OK
Content-Length: 13057672
Content-Type: application/octet-stream
Last-Modified: Wed, 10 Oct 2005 00:56:34 GMT
Accept-Ranges: bytes
ETag: "2f38a6cac7cec51:160c"
Server: Microsoft-IIS/6.0
X-Powered-By: ASP.NET
Date: Wed, 16 Nov 2005 01:57:54 GMT
Connection: close

不用逐一解釋,很多東西一看幾乎就明白了,只說我們大家都關心內容吧。

第一行是協議名稱及版本號,空格后面會有一個三位數的數字,是HTTP協議的響應狀態碼,200表示成功,OK是對狀態碼的簡短文字描述。狀態碼共有5類:
1xx屬于通知類;
2xx屬于成功類;
3xx屬于重定向類;
4xx屬于客戶端錯誤類;
5xx屬于服務端錯誤類。
對于狀態碼,相信大家對404應該很熟悉,如果向一個服務器請求一個不存在的文件,就會得到該錯誤,通常瀏覽器也會顯示類似“HTTP 404 - 未找到文件”這樣的錯誤。Content-Length字段是一個比較重要的字段,它標明了服務器返回數據的長度,這個長度是不包含HTTP頭長度的。換句話說,我們的請求中并沒有Range字段(后面會說到),表示我們請求的是整個文件,所以Content-Length就是整個文件的大小。其余各字段是一些關于文件和服務器的屬性信息。

這段返回數據同樣是以最后一行的結束標志(回車換行)和一個額外的回車換行作為結束,即“\r\n\r\n”。而“\r\n\r\n”后面緊接的就是文件的內容了,這樣我們就可以找到“\r\n\r\n”,并從它后面的第一個字節開始,源源不斷的讀取,再寫到文件中了。

以上就是通過HTTP協議實現文件下載的全過程。但還不能實現斷點續傳,而實際上斷點續傳的實現非常簡單,只要在請求中加一個Range字段就可以了。

假如一個文件有1000個字節,那么其范圍就是0-999,則:

Range: bytes=500-????? 表示讀取該文件的500-999字節,共500字節。
Range: bytes=500-599?? 表示讀取該文件的500-599字節,共100字節。
Range還有其它幾種寫法,但上面這兩種是最常用的,對于斷點續傳也足矣了。如果HTTP請求中包含Range字段,那么服務器會返回206(Partial Content),同時HTTP頭中也會有一個相應的Content-Range字段,類似下面的格式:
Content-Range: bytes 500-999/1000
Content-Range字段說明服務器返回了文件的某個范圍及文件的總長度。這時Content-Length字段就不是整個文件的大小了,而是對應文件這個范圍的字節數,這一點一定要注意。

一切好像基本上沒有什么問題了,本來我也是這么認為的,但事實并非如此。如果我們請求的文件的URL是類似http://www.server.com/filename.exe這樣的文件,則不會有問題。但是很多軟件下載網站的文件下載鏈接都是通過程序重定向的,比如pchome的ACDSee的HTTP下載地址是:

http://download.pchome.net/php/tdownload2.php?sid=5547&url=/multimedia/viewer/acdc31sr1b051007.exe&svr=1&typ=0

這種地址并沒有直接標識文件的位置,而是通過程序進行了重定向。如果向服務器請求這樣的URL,服務器就會返回302(Moved Temporarily),意思就是需要重定向,同時在HTTP頭中會包含一個Location字段,Location字段的值就是重定向后的目的URL。這時就需要斷開當前的連接,而向這個重定向后的服務器發請求。

???? 好了,原理基本上就是這些了。其實裝個Sniffer好好分析一下,很容易就可以分析出來的。不過NetAnts也幫了我一些忙,它的文件下載日志對開發人員還是很有幫助的。

本文引自:http://hi.baidu.com/chinessnetstone/blog/item/603d20094009468ad0581b23.html

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产美女精品免费电影| 一区二区三区日韩| 亚洲精品视频在线播放| 亚洲国产日韩在线一区模特| 在线观看欧美激情| 亚洲国内自拍| 夜夜爽av福利精品导航| 亚洲一区二区三区免费在线观看| 99精品国产热久久91蜜凸| 亚洲美女在线国产| 亚洲免费视频在线观看| 久久精品免费电影| 欧美ab在线视频| 日韩视频第一页| 亚洲男人av电影| 久久这里只有| 国产精品99一区二区| 国产一区二区高清不卡| 亚洲风情亚aⅴ在线发布| 亚洲乱码国产乱码精品精| 亚洲欧美国产精品va在线观看 | 国产精品久久久久9999吃药| 国产九色精品成人porny| 在线日韩欧美视频| 亚洲一区欧美二区| 欧美大色视频| 欧美一区二区三区日韩视频| 欧美电影免费观看高清| 国产精品亚洲综合一区在线观看| 一区二区亚洲精品国产| 亚洲午夜精品视频| 欧美日韩另类丝袜其他| 99国产精品视频免费观看| 亚洲久久成人| 久久精品日韩欧美| 国产精品久久久999| 在线免费观看日本一区| 亚洲欧美日韩另类精品一区二区三区| 蜜桃av综合| 午夜精品久久久久久久久| 欧美精品在线观看播放| 一区二区三区在线观看国产| 亚洲欧美精品一区| 亚洲精品一区二区三区99| 狼人天天伊人久久| 国产自产高清不卡| 亚洲一区一卡| 亚洲精品美女久久7777777| 亚洲一区二区欧美日韩| 欧美精品福利在线| 亚洲精品在线二区| 亚洲福利一区| 免费国产自线拍一欧美视频| 黄色在线一区| 开心色5月久久精品| 亚洲欧美视频一区| 国产精品五月天| 亚洲免费在线观看视频| 99riav久久精品riav| 欧美精品免费视频| 一区二区日韩免费看| 91久久精品一区二区别| 欧美成黄导航| 99re这里只有精品6| 91久久精品一区二区别| 欧美精品日韩www.p站| 亚洲三级影院| 亚洲精品国产无天堂网2021| 欧美精品观看| 亚洲欧美日韩精品久久奇米色影视| av不卡在线观看| 国产精品美腿一区在线看| 性欧美xxxx大乳国产app| 亚洲欧美日韩在线观看a三区| 国产精品一区免费观看| 久久精品国产第一区二区三区| 亚洲欧美在线磁力| 好看的亚洲午夜视频在线| 久久综合中文色婷婷| 蜜臀久久久99精品久久久久久| 亚洲欧洲日夜超级视频| 日韩午夜在线电影| 国产麻豆一精品一av一免费| 久久久美女艺术照精彩视频福利播放| 久久国产乱子精品免费女| 亚洲电影欧美电影有声小说| 亚洲区中文字幕| 国产麻豆综合| 亚洲电影有码| 国产精品一区二区久久久久| 老司机精品福利视频| 久久国产精品高清| 久久影音先锋| 欧美精品三级| 久久精品国产久精国产一老狼| 久久久国产精彩视频美女艺术照福利 | 亚洲黄网站黄| 欧美视频免费在线| 久久精品日韩欧美| 欧美激情中文字幕在线| 欧美在线播放| 欧美精品日韩www.p站| 久久国产精品电影| 欧美精品一区在线| 玖玖玖国产精品| 欧美小视频在线| 亚洲风情在线资源站| 国产日韩欧美亚洲| 亚洲精选在线| 亚洲国产精品精华液网站| 一本色道久久综合亚洲二区三区 | 久久精品日韩| 亚洲私拍自拍| 欧美成人性生活| 久久黄色级2电影| 欧美视频成人| 亚洲欧洲日本国产| 亚洲成人在线网| 亚洲欧美综合v| 亚洲欧美成aⅴ人在线观看| 免费人成精品欧美精品| 久久久久久久久一区二区| 欧美色欧美亚洲另类二区| 欧美成人精品在线观看| 国产亚洲一区二区三区在线观看| aa亚洲婷婷| 亚洲视频狠狠| 欧美日韩免费观看一区=区三区| 欧美国产日韩精品免费观看| 国内一区二区在线视频观看| 亚洲欧美日韩在线| 性欧美videos另类喷潮| 国产精品午夜电影| 亚洲午夜精品网| 亚洲自拍啪啪| 国产精品乱码一区二区三区| 亚洲精品美女在线观看| a4yy欧美一区二区三区| 欧美日韩国产免费观看| 亚洲免费精品| 午夜亚洲激情| 国产一区二区在线免费观看 | 国产目拍亚洲精品99久久精品| 亚洲开发第一视频在线播放| 99re亚洲国产精品| 欧美午夜片在线观看| 亚洲在线观看免费| 欧美伊人久久| 欧美aaa级| 欧美成人精品福利| 亚洲激情一区二区三区| 夜夜爽99久久国产综合精品女不卡| 麻豆成人精品| 亚洲国产精品电影| 99国产精品99久久久久久| 欧美激情一区二区久久久| 亚洲人精品午夜| 亚洲欧美激情四射在线日 | 国产精品va在线播放| 亚洲香蕉网站| 久久久夜色精品亚洲| 亚洲国产国产亚洲一二三| 欧美精品亚洲二区| 亚洲字幕一区二区| 久热成人在线视频| 日韩视频一区二区三区在线播放免费观看| 蜜乳av另类精品一区二区| 亚洲三级电影全部在线观看高清| 亚洲视频中文字幕| 狠狠色综合日日| 欧美视频一区二| 久久综合久久综合这里只有精品 | 亚洲午夜羞羞片| 老妇喷水一区二区三区| 日韩一级黄色大片| 国产日韩欧美91| 欧美成人69av| 亚洲自拍偷拍视频| 亚洲国产精品福利| 欧美在线视频不卡| 99精品欧美一区二区三区| 国产亚洲aⅴaaaaaa毛片| 欧美精品1区2区| 久久精品一区二区三区不卡| 一二三四社区欧美黄| 久久综合久久综合九色| 亚洲中无吗在线| 亚洲韩国青草视频| 国产亚洲欧美色| 欧美视频官网| 欧美精品二区三区四区免费看视频| 欧美一区二区三区的| 一区二区三区蜜桃网| 亚洲国产综合91精品麻豆| 久久综合狠狠综合久久综合88| 午夜亚洲福利| 性亚洲最疯狂xxxx高清| 一本色道久久综合亚洲精品不卡| 亚洲高清123| 亚洲国产成人av在线|