国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類(lèi)導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - 在Python中使用mechanize模塊模擬瀏覽器功能

在Python中使用mechanize模塊模擬瀏覽器功能

2020-06-22 10:11xrzs Python

這篇文章主要介紹了在Python中使用mechanize模塊模擬瀏覽器功能,包括使用cookie和設(shè)置代理等功能的實(shí)現(xiàn),需要的朋友可以參考下

知道如何快速在命令行或者python腳本中實(shí)例化一個(gè)瀏覽器通常是非常有用的。
每次我需要做任何關(guān)于web的自動(dòng)任務(wù)時(shí),我都使用這段python代碼去模擬一個(gè)瀏覽器。
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import mechanize
import cookielib
# Browser
br = mechanize.Browser()
# Cookie Jar
cj = cookielib.LWPCookieJar()
br.set_cookiejar(cj)
# Browser options
br.set_handle_equiv(True)
br.set_handle_gzip(True)
br.set_handle_redirect(True)
br.set_handle_referer(True)
br.set_handle_robots(False)
# Follows refresh 0 but not hangs on refresh > 0
br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time=1)
# Want debugging messages?
#br.set_debug_http(True)
#br.set_debug_redirects(True)
#br.set_debug_responses(True)
# User-Agent (this is cheating, ok?)
br.addheaders = [('User-agent', 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.1')]

現(xiàn)在你得到了一個(gè)瀏覽器的示例,br對(duì)象。使用這個(gè)對(duì)象,便可以打開(kāi)一個(gè)頁(yè)面,使用類(lèi)似如下的代碼:
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# Open some site, let's pick a random one, the first that pops in mind:
r = br.open('http://google.com')
html = r.read()
# Show the source
print html
# or
print br.response().read()
# Show the html title
print br.title()
# Show the response headers
print r.info()
# or
print br.response().info()
# Show the available forms
for f in br.forms():
  print f
# Select the first (index zero) form
br.select_form(nr=0)
# Let's search
br.form['q']='weekend codes'
br.submit()
print br.response().read()
# Looking at some results in link format
for l in br.links(url_regex='stockrt'):
  print l

如果你訪問(wèn)的網(wǎng)站需要驗(yàn)證(http basic auth),那么:
 

?
1
2
3
4
# If the protected site didn't receive the authentication data you would
# end up with a 410 error in your face
br.add_password('http://safe-site.domain', 'username', 'password')
br.open('http://safe-site.domain')

由于之前使用了Cookie Jar,你不需要管理網(wǎng)站的登錄session。也就是不需要管理需要POST一個(gè)用戶名和密碼的情況。
通常這種情況,網(wǎng)站會(huì)請(qǐng)求你的瀏覽器去存儲(chǔ)一個(gè)session cookie除非你重復(fù)登陸,
而導(dǎo)致你的cookie中含有這個(gè)字段。所有這些事情,存儲(chǔ)和重發(fā)這個(gè)session cookie已經(jīng)被Cookie Jar搞定了,爽吧。
同時(shí),你可以管理你的瀏覽器歷史:
 

?
1
2
3
4
5
6
7
8
9
10
11
12
# Testing presence of link (if the link is not found you would have to
# handle a LinkNotFoundError exception)
br.find_link(text='Weekend codes')
# Actually clicking the link
req = br.click_link(text='Weekend codes')
br.open(req)
print br.response().read()
print br.geturl()
# Back
br.back()
print br.response().read()
print br.geturl()

下載一個(gè)文件:
 

?
1
2
3
4
# Download
f = br.retrieve('http://www.google.com.br/intl/pt-BR_br/images/logo.gif')[0]
print f
fh = open(f)

為http設(shè)置代理
 

?
1
2
3
4
5
6
# Proxy and user/password
br.set_proxies({"http": "joe:password@myproxy.example.com:3128"})
# Proxy
br.set_proxies({"http": "myproxy.example.com:3128"})
# Proxy password
br.add_proxy_password("joe", "password")

但是,如果你只想要打開(kāi)網(wǎng)頁(yè),而不需要之前所有神奇的功能,那你可以:
 

?
1
2
3
4
5
6
7
# Simple open?
import urllib2
print urllib2.urlopen('http://stockrt.github.com').read()
# With password?
import urllib
opener = urllib.FancyURLopener()
print opener.open('http://user:password@stockrt.github.com').read()

你可以通過(guò) mechanize官方網(wǎng)站 , mechanize文檔 和ClientForm的文檔 了解更多。


原文來(lái)自:http://reyoung.me/index.php/2012/08/08/%E7%BF%BB%E8%AF%91%E4%BD%BF%E7%94%A8python%E6%A8%A1%E4%BB%BF%E6%B5%8F%E8%A7%88%E5%99%A8%E8%A1%8C%E4%B8%BA/

——————————————————————————————

最后來(lái)聊下通過(guò)代碼訪問(wèn)頁(yè)面時(shí)的一個(gè)很重要的概念和技術(shù):cookie

我們都知道HTTP是無(wú)連接的狀態(tài)協(xié)議,但是客戶端和服務(wù)器端需要保持一些相互信息,比如cookie,有了cookie,服務(wù)器才能知道剛才是這個(gè)用戶登錄了網(wǎng)站,才會(huì)給予客戶端訪問(wèn)一些頁(yè)面的權(quán)限。
比如用瀏覽器登錄新浪微博,必須先登錄,登陸成功后,打開(kāi)其他的網(wǎng)頁(yè)才能夠訪問(wèn)。用程序登錄新浪微博或其他驗(yàn)證網(wǎng)站,關(guān)鍵點(diǎn)也在于需要保存cookie,之后附帶cookie再來(lái)訪問(wèn)網(wǎng)站,才能夠達(dá)到效果。
這里就需要Python的cookielib和urllib2等的配合,將cookielib綁定到urllib2在一起,就能夠在請(qǐng)求網(wǎng)頁(yè)的時(shí)候附帶cookie。
具體做法,首先第一步,用firefox的httpfox插件,在瀏覽器衷開(kāi)始瀏覽新浪微博首頁(yè),然后登陸,從httpfox的記錄中,查看每一步發(fā)送了那些數(shù)據(jù)請(qǐng)求了那個(gè)URL;之后再python里面,模擬這個(gè)過(guò)程,用urllib2.urlopen發(fā)送用戶名密碼到登陸頁(yè)面,獲取登陸后的cookie,之后訪問(wèn)其他頁(yè)面,獲取微博數(shù)據(jù)。

cookielib模塊的主要作用是提供可存儲(chǔ)cookie的對(duì)象,以便于與urllib2模塊配合使用來(lái)訪問(wèn)Internet資源。例如可以利用本模塊的CookieJar類(lèi)的對(duì)象來(lái)捕獲cookie并在后續(xù)連接請(qǐng)求時(shí)重新發(fā)送。coiokielib模塊用到的對(duì)象主要有下面幾個(gè):CookieJar、FileCookieJar、MozillaCookieJar、LWPCookieJar。
urllib模塊和urllib模塊類(lèi)似,用來(lái)打開(kāi)URL并從中獲取數(shù)據(jù)。與urllib模塊不同的是,urllib模塊不僅可以使用urlopen()函數(shù)還可以自定義Opener來(lái)訪問(wèn)網(wǎng)頁(yè)。同時(shí)要注意:urlretrieve()函數(shù)是urllib模塊中的,urllib2模塊中不存在該函數(shù)。但是使用urllib2模塊時(shí)一般都離不開(kāi)urllib模塊,因?yàn)镻OST的數(shù)據(jù)需要使用urllib.urlencode()函數(shù)來(lái)編碼。

cookielib模塊一般與urllib2模塊配合使用,主要用在urllib2.build_oper()函數(shù)中作為urllib2.HTTPCookieProcessor()的參數(shù)。使用方法如下面登錄人人網(wǎng)的代碼:
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
#! /usr/bin/env python
#coding=utf-8
import urllib2
import urllib
import cookielib
data={"email":"用戶名","password":"密碼"} #登陸用戶名和密碼
post_data=urllib.urlencode(data)
cj=cookielib.CookieJar()
opener=urllib2.build_opener(urllib2.HTTPCookieProcessor(cj))
headers ={"User-agent":"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1"}
req=urllib2.Request("http://www.renren.com/PLogin.do",post_data,headers)
content=opener.open(req)
print content.read().decode("utf-8").encode("gbk")

具體請(qǐng)參考:

http://www.crazyant.net/796.html  Python使用cookielib和urllib2模擬登陸新浪微博并抓取數(shù)據(jù)

http://my.oschina.net/duhaizhang/blog/69342  urllib2模塊

https://docs.python.org/2/library/cookielib.html  cookielib — Cookie handling for HTTP clients

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲色图88| 色视频www在线播放国产人成 | 亚洲视频 中文字幕 | 在线观看亚洲视频 | 日韩一区二区三区在线观看 | 日本久久综合 | 538在线精品 | 国产一区中文字幕 | 久久久久久久国产 | 国产黄色网址在线观看 | 久久精品中文字幕一区二区 | 一级毛片国产 | 久久免费99精品久久久久久 | 成人免费一区二区三区视频网站 | 成人国产精品久久久 | 国产在线a| 天天干天天草 | 成人欧美一区二区三区色青冈 | 国产精品中文在线 | 国产美女视频网站 | 欧美成人一区二区三区片免费 | 色婷婷综合久久久中字幕精品久久 | 国产一区二区三区在线 | 黄色毛片在线看 | 国产精品美女久久久久久免费 | 午夜影院网站 | 国产欧美日韩 | 美女扒开尿口来摸 | 大片免费播放在线观看视频 | 久久69精品久久久久久国产越南 | 98成人网| 91羞羞| 精品国产一二三区 | 新久久久 | 美女福利网站 | 国产精品久久久久久久久久东京 | 北条麻妃99精品青青久久 | 亚洲91av| 香蕉成人啪国产精品视频综合网 | 自拍视频网 | 午夜免费小视频 |