为什么我不能使用Python“请求”库填写此表单?

时间:2015-03-16 12:25:46

标签: python python-2.7 python-requests

我想在Python中使用requests库填写登录表单。如下所示,字段名称为usernamepasswordenter image description here

所以我写了下面的剧本:

session = requests.session()
p = session.post("http://192.168.94.1/SubSystem/Portal/Index1/Login/Login2.aspx", {'username':'myUsername','password':'myPassword'})
print 'headers', p.headers
print 'cookies', requests.utils.dict_from_cookiejar(session.cookies)
print 'html',  p.text

问题是,当我运行它时,它会再次返回登录页面!我的计划出了什么问题?

更新:

我也尝试将参数作为数据发送,但没有改变。即下面的代码也返回相同的输出:

payload = {'username': 'myUsername', 'password': 'myPassword'}
r = requests.post("http://192.168.94.1/SubSystem/Portal/Index1/Login/Login2.aspx", data=payload)
print(r.text)

更新2:

我使用 Burp Suit 来捕获数据包以查看差异:

这是我的浏览器发送的数据包:

POST /SubSystem/Portal/Index1/Login/Login2.aspx HTTP/1.1
Host: 192.168.94.1
Proxy-Connection: keep-alive
Content-Length: 134
Cache-Control: max-age=0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Origin: http://192.168.94.1
User-Agent: Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.89 Safari/537.36
Content-Type: application/x-www-form-urlencoded
Referer: http://192.168.94.1/SubSystem/Portal/Index1/Login/Login2.aspx
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8
Cookie: ASP.NET_SessionId=nntwluu5uhrldzuymsv333uc; CURRENT_LANGUAGE_2=fa

__VIEWSTATE=%2FwEPDwUKMTY5ODAzNzY1MmRkpL4TXtJfODqn0yxypIJaOzkl4YUWynT8urN%2BYYXM%2FnY%3D&Command=LOGIN&username=myUsername&password=myPassword

这就是第二个Python脚本发送的数据包:

POST /SubSystem/Portal/Index1/Login/Login2.aspx HTTP/1.1
Host: 192.168.94.1
Content-Length: 31
Accept-Encoding: gzip, deflate
Accept: */*
User-Agent: python-requests/2.4.3 CPython/2.7.0 Windows/7
Connection: keep-alive
Content-Type: application/x-www-form-urlencoded

username=myUsername&password=myPassword

2 个答案:

答案 0 :(得分:3)

看起来您首先需要发送POST请求,但是从您最近的更新中,该POST还期望一些cookie可用 - 还有一个名为" Command"的隐藏字段。需要使用值" LOGIN"发送,等等。

import requests

URL = "http://192.168.94.1/SubSystem/Portal/Index1/Login/Login2.aspx"

# Set up session object so we can store cookies across requests
session = requests.session()
# GET the page to get any initial cookies required for the POST
r = session.get(URL)
# POST to the login form (making sure to add "Command")
r = session.post(URL, data={'Command': 'LOGIN', 'username': 'x', 'password': 'y'})

关于为什么在保存页面时没有获取图像的原因是,当浏览器加载页面时,它会看到指向资源/样式表/图像的链接,并发出访问它们的更多请求 - 所有{{1} }加载"文本"页面原样。有实现这一目标的方法,但这不是作为核心问题答案的范围。


根据关于的评论我可以使用这些会话对象进行多次登录吗? - 这是一种方法...

requests

答案 1 :(得分:-1)

支持@ EsseTi的答案,使用data = Payload方法来获取它们。

import requests
payload = {'id_login': 'UserName', 'id_password': 'Password'}
url = #Your URL
something = requests.post(url, data=payload)