我用这一个砰地撞着墙头。我一直在尝试每个示例,阅读我在网上可以找到的有关使用urllib2进行基本http授权的每一个最后一点,但是我无法弄清楚是什么导致了我的具体错误。urllib2基本认证怪物
添加到无奈的是,代码工作的一个页面,而尚未另一个。登录www.mysite.com/adm的登录变得非常顺利。它认证没有问题。然而,如果我更改地址为“http://mysite.com/adm/items.php?n=201105 & C = 200”我收到此错误:
<h4 align="center" class="teal">Add/Edit Items</h4>
<p><strong>Client:</strong> </p><p><strong>Event:</strong> </p><p class="error">Not enough information to complete this task</p>
<p class="error">This is a fatal error so I am exiting now.</p>
搜索谷歌已经导致零信息这个错误。
ADM的是框架集页面,我不知道这是相关的。
下面是当前的代码:
import urllib2, urllib
import sys
import re
import base64
from urlparse import urlparse
theurl = 'http://xxxxxmedia.com/adm/items.php?n=201105&c=200'
username = 'XXXX'
password = 'XXXX'
passman = urllib2.HTTPPasswordMgrWithDefaultRealm()
passman.add_password(None, theurl,username,password)
authhandler = urllib2.HTTPBasicAuthHandler(passman)
opener = urllib2.build_opener(authhandler)
urllib2.install_opener(opener)
pagehandle = urllib2.urlopen(theurl)
url = 'http://xxxxxxxmedia.com/adm/items.php?n=201105&c=200'
values = {'AvAudioCD': 1,
'AvAudioCDDiscount': 00, 'AvAudioCDPrice': 50,
'ProductName': 'python test', 'frmSubmit': 'Submit' }
#opener2 = urllib2.build_opener(urllib2.HTTPCookieProcessor())
data = urllib.urlencode(values)
req = urllib2.Request(url, data)
response = urllib2.urlopen(req)
这只是众多版本我试过之一。我已经跟踪了Urllib2手册中的所有示例,但仍然收到相同的错误。
任何人都可以指出我做错了什么?
它看起来像你的代码工作,但不是你连接到的网站。它在浏览器中工作吗?由于页面包含框架,你看过它的源代码吗? – 2011-02-03 06:41:56
是的,它在浏览器中工作。我已经检查出它的来源与萤火虫。管理网站使用此样式代码进入html页面:
– Zack 2011-02-03 07:27:52@jd是的,它在浏览器中工作。我已经检查出它的来源与萤火虫。我不完全确定要寻找什么。我注意到我可以在每个页面上使用python进行身份验证,除了那些在地址IE中有参数的页面。 ..dia.com/ADM/items.php?N = 201105&amp; C = 200' 。 – Zack 2011-02-03 07:37:25