我试图使用requests库登录一个站点,但它不能像往常一样工作。
我希望站点像通过浏览器访问时一样发送cookie:
csrftoken: Bl5DOVcUge5VeRv771nAIUNbxmm9Z9l2但是,我收到的全部内容如下:
__cfduid: d2f8e300a0b867e8a6147462f3977f8b11375815648197 for .example2.net/这个可以像我预期的那样工作:
agent1 = requests.session()
agent1.get('https://example1.com/')
print agent1.cookies返回:
<<class 'requests.cookies.RequestsCookieJar'>[<Cookie example1session=6ce1fa7fc23669078c9cf86001b34c4f for .example1.com/>, <Cookie countrycode=FR for example1.com/>, <Cookie csrftoken=ETcsKwBgUkPxPjgN6hJaOXv5byIL15mE for example1.com/>, <Cookie lat=46.0 for example1.com/>, <Cookie lon=2.0 for example1.com/>]>这个不是:
agent2 = requests.session()
agent2.get('https://www.example2.net')
print agent2.cookies它返回:
<<class 'requests.cookies.RequestsCookieJar'>[<Cookie __cfduid=d14644e3e542bf4165a0714c0e77d04eb1375816707171 for .example2此__cfduid cookie与站点运行的CloudFlare DDOS保护服务有关。这会与这个问题有关吗?
发布于 2014-05-08 06:09:53
我发现了一个类似的问题。在我的例子中,我试图登录,发布到一个url,但服务器重定向了我。在这个重定向过程中,设置了cookie (正如我在浏览器中看到的那样),但是在我的python程序中没有设置cookie。
我发现定义一些类似于浏览器的头并禁用重定向解决了这个问题。
headers = {
'Host': 'www.example.net',
'Origin': 'http://www.example.net',
'Referer': 'http://www.example.net/',
'User-Agent': 'Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/34.0.1847.131 Safari/537.36'}
session = requests.Session()
session.headers = headers
session.post('http://www.example.net/login/', data=values, allow_redirects=False)https://stackoverflow.com/questions/18088825
复制相似问题