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

首頁 > 編程 > Python > 正文

Python中使用socket發(fā)送HTTP請求數(shù)據(jù)接收不完整問題解決方法

2019-11-25 18:00:25
字體:
來源:轉載
供稿:網友

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

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

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

這樣發(fā)現(xiàn)所有請求的數(shù)據(jù)均被返回了,看來要想做好網絡編程,深入理解TCP/IP協(xié)議是非常必要的。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 乌兰浩特市| 个旧市| 贵州省| 腾冲县| 蓝田县| 望奎县| 满洲里市| 定襄县| 剑川县| 电白县| 丘北县| 同仁县| 柞水县| 贵阳市| 涟源市| 宜兰县| 沙河市| 昌黎县| 旬阳县| 论坛| 玉门市| 安仁县| 双辽市| 平利县| 屯门区| 南昌县| 文成县| 双流县| 龙陵县| 萍乡市| 偏关县| 乌什县| 舞阳县| 合肥市| 山丹县| 台中市| 西乌| 西青区| 顺义区| 馆陶县| 酉阳|