麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Python > 正文

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

2020-02-23 06:22:42
字體:
供稿:網(wǎng)友

由于工作的需求,需要用python做一個類似網(wǎng)絡(luò)爬蟲的采集器。雖然Python的urllib模塊提供更加方便簡潔操作,但是涉及到一些底層的需求,如手動設(shè)定User-Agent,Referer等,所以選擇了直接用socket進行設(shè)計。當然,這樣的話,需要對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)一個比較重要的問題,運行結(jié)果只返回了HTTP的頭部信息,網(wǎng)頁的內(nèi)容則沒有被返回。網(wǎng)上查找了很多資料,一無所獲,經(jīng)過一夜的思考,突然想到了一個問題,有可能我請求的資源非常大,一個網(wǎng)絡(luò)的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ù)均被返回了,看來要想做好網(wǎng)絡(luò)編程,深入理解TCP/IP協(xié)議是非常必要的。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美一页 | 国产精品白嫩白嫩大学美女 | 草草视频在线播放 | 国产午夜精品在线 | a网站在线 | 成人免费一区二区三区在线观看 | 青青草成人影视 | 黄色片视频免费观看 | 中文字幕线观看 | 久久777国产线看观看精品 | 免费欧美一级视频 | 石原莉奈日韩一区二区三区 | 男女一边摸一边做羞羞视频免费 | 国产日产精品一区二区三区四区 | 91精品国产乱码久久久久久久久 | 成人毛片视频免费看 | 国产午夜精品一区二区三区视频 | 久久亚洲春色中文字幕久久 | 日本高清在线免费 | 毛片在线免费播放 | 久久精品成人影院 | 国产精品久久久不卡 | 亚洲男人天堂 | 手机av在线电影 | 在线91视频 | 久草在线资源福利站 | 亚洲午夜1000理论片aa | 粉嫩蜜桃麻豆免费大片 | 中文日韩在线 | 久久久一区二区三区视频 | 欧美日韩亚洲视频 | 日本精品中文字幕 | 成年人视频在线免费观看 | 久久久久久久99 | 国产91小视频在线观看 | 护士xxxx| 日韩欧美电影一区二区三区 | 毛片大全免费看 | 国产羞羞视频在线观看 | 在线播放免费人成毛片乱码 | 黄色片网站免费在线观看 |