我试图向以下页面发起POST请求:http://search.cpsa.ca/PhysicianSearch
为了模拟点击“搜索”按钮而不填写表单,从而向页面添加数据。我通过在Chrome开发者工具的网络选项卡下查看按钮并点击获取了POST头信息。我发布这篇文章的原因是我认为我可能没有获取正确的头信息,在其他类似问题的解决方案中只是复制粘贴是行不通的。
这个格式是否正确并且我抓取了正确的信息?我以前从未进行过POST请求。
这是我设法整理出来的内容:
import urllib.parse
import urllib.request
data = urllib.parse.urlencode({'Host': 'search.cpsa.ca', 'Connection': 'keep-alive', 'Content-Length': 23796,
'Origin': 'http://search.cpsa.ca', 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
'Cahce-Control': 'no-cache', 'X-Requested-With': 'XMLHttpRequest',
'X-MicrosoftAjax': 'Delta=true', 'Accept': '*/*',
'Referer': 'http://search.cpsa.ca/PhysicianSearch',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'en-GB,en-US;q=0.8,en;q=0.6',
'Cookie': 'ASP.NET_SessionId=kcwsgio3dchqjmyjtwue402c; _ga=GA1.2.412607756.1459536682; _gat=1'})
url = "http://www.musi-cal.com/cgi-bin/query?%s"
data = data.encode('ascii')
with urllib.request.urlopen("http://search.cpsa.ca/PhysicianSearch", data) as f:
print(f.read().decode('utf-8'))
这个解决方案输出了页面的HTML,但没有任何我想从POST请求中检索的数据。