基于Python模擬瀏覽器發(fā)送http請(qǐng)求
1.使用 urllib2 實(shí)現(xiàn)
#! /usr/bin/env python# -*- coding=utf-8 -*- import urllib2url='https://www.baidu.com'req_header = {'User-Agent':'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11','Accept':'text/html;q=0.9,*/*;q=0.8','Accept-Charset':'ISO-8859-1,utf-8;q=0.7,*;q=0.3','Accept-Encoding':'gzip','Connection':'close','Referer':None #注意如果依然不能抓取的話,這里可以設(shè)置抓取網(wǎng)站的host}req_timeout = 5req = urllib2.Request(url,None,req_header)resp = urllib2.urlopen(req,None,req_timeout)html = resp.read()print(html)
2.使用 requests 模塊
(1).get請(qǐng)求
#-*- coding:utf-8 -*-import requestsurl = 'https://www.baidu.com'payload = {'key1': 'value1', 'key2': 'value2'}r = requests.get(url, params=payload)print r.text
(2).post請(qǐng)求
#-*- coding:utf-8 -*-import requestsurl1 = 'http://www.exanple.com/login'#登陸地址url2 = 'http://www.example.com/main'#需要登陸才能訪問(wèn)的地址data={'user':'user','password':'pass'}headers = { 'Accept':'text/html,application/xhtml+xml,application/xml;', 'Accept-Encoding':'gzip', 'Accept-Language':'zh-CN,zh;q=0.8', 'Referer':'http://www.example.com/', 'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.90 Safari/537.36' }res1 = requests.post(url1, data=data, headers=headers)res2 = requests.get(url2, cookies=res1.cookies, headers=headers)print res2.content#獲得二進(jìn)制響應(yīng)內(nèi)容print res2.raw#獲得原始響應(yīng)內(nèi)容,需要stream=Trueprint res2.raw.read(50)print type(res2.text)#返回解碼成unicode的內(nèi)容print res2.urlprint res2.history#追蹤重定向print res2.cookiesprint res2.cookies['example_cookie_name']print res2.headersprint res2.headers['Content-Type']print res2.headers.get('content-type')print res2.json#講返回內(nèi)容編碼為jsonprint res2.encoding#返回內(nèi)容編碼print res2.status_code#返回http狀態(tài)碼print res2.raise_for_status()#返回錯(cuò)誤狀態(tài)碼
(3).使用session對(duì)象的寫(xiě)法
#-*- coding:utf-8 -*-import requestss = requests.Session()url1 = 'http://www.exanple.com/login'#登陸地址url2 = 'http://www.example.com/main'#需要登陸才能訪問(wèn)的地址data={'user':'user','password':'pass'}headers = { 'Accept':'text/html,application/xhtml+xml,application/xml;', 'Accept-Encoding':'gzip', 'Accept-Language':'zh-CN,zh;q=0.8', 'Referer':'http://www.example.com/', 'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.90 Safari/537.36' }prepped1 = requests.Request('POST', url1, data=data, headers=headers).prepare()s.send(prepped1)'''也可以這樣寫(xiě)res = requests.Request('POST', url1,data=data,headers=headers)prepared = s.prepare_request(res)# do something with prepped.body# do something with prepped.headerss.send(prepared)'''prepare2 = requests.Request('POST', url2, headers=headers).prepare()res2 = s.send(prepare2)print res2.content'''另一種寫(xiě)法'''#-*- coding:utf-8 -*-import requestss = requests.Session()url1 = 'http://www.exanple.com/login'#登陸地址url2 = 'http://www.example.com/main'#需要登陸才能訪問(wèn)的頁(yè)面地址data={'user':'user','password':'pass'}headers = { 'Accept':'text/html,application/xhtml+xml,application/xml;', 'Accept-Encoding':'gzip', 'Accept-Language':'zh-CN,zh;q=0.8', 'Referer':'http://www.example.com/', 'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.90 Safari/537.36' }res1 = s.post(url1, data=data)res2 = s.post(url2)print(resp2.content)
3.其他的一些請(qǐng)求方式
>>> r = requests.put('http://httpbin.org/put')>>> r = requests.delete('http://httpbin.org/delete')>>> r = requests.head('http://httpbin.org/get')>>> r = requests.options(http://httpbin.org/get)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 解決Android Studio Design界面不顯示layout控件的問(wèn)題2. python mysql 字段與關(guān)鍵字沖突的解決方式3. bootstrap select2 動(dòng)態(tài)從后臺(tái)Ajax動(dòng)態(tài)獲取數(shù)據(jù)的代碼4. Python加載數(shù)據(jù)的5種不同方式(收藏)5. python讀取中文路徑時(shí)出錯(cuò)(2種解決方案)6. Python用K-means聚類算法進(jìn)行客戶分群的實(shí)現(xiàn)7. python編寫(xiě)五子棋游戲8. Java源碼解析之接口List9. Java xml數(shù)據(jù)格式返回實(shí)現(xiàn)操作10. layui Ajax請(qǐng)求給下拉框賦值的實(shí)例
