国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python中使用socket發送HTTP請求數據接收不完整問題解決方法

2020-02-23 06:22:42
字體:
來源:轉載
供稿:網友

由于工作的需求,需要用python做一個類似網絡爬蟲的采集器。雖然Python的urllib模塊提供更加方便簡潔操作,但是涉及到一些底層的需求,如手動設定User-Agent,Referer等,所以選擇了直接用socket進行設計。當然,這樣的話,需要對HTTP協議比較熟悉,HTTP協議這里就不做講解了。整個python的代碼如下:

#!/usr/bin env pythonimport sockethost="www.baidu.com"se=socket.socket(socket.AF_INET,socket.SOCK_STREAM)se.connect((host,80))se.send("GET / HTTP/1.1/n")se.send("Accept:text/html,application/xhtml+xml,*/*;q=0.8/n")#se.send("Accept-Encoding:gzip,deflate,sdch/n")se.send("Accept-Language:zh-CN,zh;q=0.8,en;q=0.6/n")se.send("Cache-Control:max-age=0/n")se.send("Connection:keep-alive/n")se.send("Host:"+host+"/r/n")se.send("Referer:http://www.baidu.com//n")se.send("user-agent: Googlebot/n/n")print se.recv(1024)

代碼運行正常,但是發現一個比較重要的問題,運行結果只返回了HTTP的頭部信息,網頁的內容則沒有被返回。網上查找了很多資料,一無所獲,經過一夜的思考,突然想到了一個問題,有可能我請求的資源非常大,一個網絡的IP包的大小,它是受很多因素制約的,最典型的便是MTU(最大傳輸單元),那么會不會我請求的數據被分割了,HTTP的頭部信息只是一部分,其它數據還在傳輸或者緩沖區呢?于是做了這樣一個遍歷:

while True:  buf = se.recv(1024)  if not len(buf):    break  print buf

這樣發現所有請求的數據均被返回了,看來要想做好網絡編程,深入理解TCP/IP協議是非常必要的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 肥城市| 印江| 泸州市| 丰原市| 榆林市| 陇南市| 怀仁县| 南宁市| 乐清市| 墨玉县| 昌平区| 阳原县| 建宁县| 冕宁县| 巫溪县| 光泽县| 西宁市| 阿合奇县| 武宣县| 商城县| 沛县| 建水县| 林口县| 株洲市| 平陆县| 新宾| 余姚市| 霞浦县| 舟山市| 永吉县| 南靖县| 涞源县| 靖边县| 洪江市| 陆丰市| 怀仁县| 阿城市| 香格里拉县| 甘南县| 漠河县| 岳西县|