我正在使用 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没有命名他们的表单。