[英]How to authenticate a site with Python using urllib2?
在Stackoverflow和网络上阅读了很多内容后,我仍然在努力让事情发挥作用。
我的挑战:使用Python和urllib2访问我所属的网站的受限制部分。
从我读过的代码应该是这样的:
mgr = urllib2.HTTPPasswordMgrWithDefaultRealm()
url = 'http://www.domain.com'
mgr.add_password(None, url, 'username', 'password')
handler = urllib2.HTTPBasicAuthHandler(mgr)
opener = urllib2.build_opener(handler)
urllib2.install_opener(opener)
try:
response = urllib2.urlopen('http://www.domain.com/restrictedpage')
page = response.read()
print page.geturl()
except IOError, e:
print e
打印不打印“http://www.domain.com/restrictedpage”,但显示“http://www.domain.com/login”,因此我的凭据未存储/处理,我正在重定向。
我怎样才能让它发挥作用? 我已经尝试了好几天,并且一直在追求同样的死胡同。 我已经尝试了所有我找不到的例子。
我的主要问题是:使用Python和urllib2对网站进行身份验证需要什么? 快速提问:我做错了什么?
首先手动检查成功通过身份验证后的实际情况(Chrome说明):
然后安装“Advanced Rest Client(ARC)”Chrome扩展程序
使用ARC构造有效的POST进行身份验证。
现在您知道标题和表单数据中包含的内容。 以下是使用请求的示例代码,该代码适用于某个特定网站:
import requests
USERNAME = 'user' # put correct usename here
PASSWORD = 'password' # put correct password here
LOGINURL = 'https://login.example.com/'
DATAURL = 'https://data.example.com/secure_data.html'
session = requests.session()
req_headers = {
'Content-Type': 'application/x-www-form-urlencoded'
}
formdata = {
'UserName': USERNAME,
'Password': PASSWORD,
'LoginButton' : 'Login'
}
# Authenticate
r = session.post(LOGINURL, data=formdata, headers=req_headers, allow_redirects=False)
print r.headers
print r.status_code
print r.text
# Read data
r2 = session.get(DATAURL)
print "___________DATA____________"
print r2.headers
print r2.status_code
print r2.text
对于HTTP Basic Auth
您可以参考: http : //www.voidspace.org.uk/python/articles/authentication.shtml
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.