使用Python mechanize登录网站?

4

我正在使用 mechanize (并遵循此教程) 尝试登录网站。我想尝试在 Twitter 上测试它,所以这是我设计的脚本:

import mechanize
import cookielib

username = 'user'   # your username/email
password = 'pass'   # your password

br = mechanize.Browser()

# set cookies
cookies = cookielib.LWPCookieJar()
br.set_cookiejar(cookies)

# browser settings (used to emulate a browser)
br.set_handle_equiv(True)
br.set_handle_redirect(True)
br.set_handle_referer(True)
br.set_handle_robots(False)
br.set_debug_http(False)
br.set_debug_responses(False)
br.set_debug_redirects(False)
br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time = 1)
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')]

br.open('http://twitter.com/') # open twitter

br.select_form(nr=1) # select the form

br['session[username_or_email]'] = username
br['session[password]'] = password
br.submit() # submit the login data
print(br.response().read) # print the response

以下是我运行脚本时Python的输出结果:
$ python twitterLoginTest.py 
<bound method response_seek_wrapper.read of <response_seek_wrapper at 0x8feaeac whose wrapped object = <closeable_response at 0x8feeaac whose fp = <socket._fileobject object at 0x8feb42c>>>>

文件名为twitterLoginTest.py。

我不太确定响应的意思,但它似乎不正确。

所以,这里有我的问题:

1)是否有更好的方法使用脚本登录网站(不仅仅是Twitter,而是任何网站,并且可以修改为适用于任何需要登录的网站的方法)?

2)我的脚本出了什么问题?

3)如何解决问题以进行登录?

我有一个假设,认为问题源自br.select_form(nr=1)(那是我选择表单的地方),但我不知道应该放什么(所以我想可能是第二个表单),因为Twitter没有命名他们的表单。

1个回答

4
我认为最后一行应该是:

我相信最后一行应该是:

print(br.response().read()) # print the response

注意在read后面有一对小括号()。你当前只是打印了read方法本身,并没有调用read方法并打印它的结果。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接