国产探花免费观看_亚洲丰满少妇自慰呻吟_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協議是非常必要的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 龙泉市| 绵竹市| 乌鲁木齐县| 溧阳市| 井冈山市| 曲阜市| 东乡县| 柘城县| 惠东县| 房山区| 龙井市| 穆棱市| 浮山县| 双江| 灵宝市| 沽源县| 柳州市| 建瓯市| 饶平县| 龙口市| 繁昌县| 荆门市| 永州市| 渝北区| 措美县| 吉木乃县| 阳新县| 镇安县| 天全县| 济阳县| 泽库县| 资兴市| 南通市| 大足县| 镇江市| 乳山市| 寿阳县| 进贤县| 凤冈县| 会理县| 信丰县|