问题描述
我目前正在尝试将我的一些代码转移到urllib3或请求中。 urllib3是减少导入模块的首选方法。
这是当前正在运行的代码。
payload = ["<username>","<password>"
browser = mechanize.browser()
browser.open(url)
browser.select_form('form1')
browser['j_username'] = payload[0]
browser['j_password'] = payload[1]
browser.submit()
到目前为止,我尝试过的是
with requests.Session() as session:
#not working
payload = { "j_username" : "<username>","j_password" : "<password>" }
req = session.post(url,data = payload)
print(req.url)
#also not working
req = session.get(url,auth=("<username>","<password>") )
print(req.url)
也不起作用:
payload = { "lang": "de","j_username": "<username>","j_password": "<password>","_eventId_proceed": "" }
req = session.post(url,data = payload)
我总是得到与返回相同的URL,所以我无法登录。
有没有办法在urllib /请求中进行此登录,还是我必须坚持机械化? 我也想比较一下这些解决方案的速度。
解决方法
最后,我找到了解决方案,也许它也可以帮助其他人。 我必须执行get请求并使用该请求中的url,因为存在重定向到登录页面的操作,并且您无法直接打开它(我会看到一个页面,就像您可能会看到此页面,因为您使用了Back在浏览安全的网站或应用程序时点击按钮...)
#url1 = url that redirects to loginpage
payload = { "lang": "de","j_username": "<username>","j_password": "<password>","_eventId_proceed": "" }
with requests.Session() as session:
loginPage = session.get(url1)
afterLogin = session.post(loginPage.url,data = payload)
wantedPage = session.get(<url of wanted page>)