【发布时间】:2015-01-15 17:44:57
【问题描述】:
我无法使用它的 Web 服务从 Bugzilla(我的版本是 4.2.5)上的错误中检索所有信息(例如 cmets、附件、估计时间...)。我有所有错误的 ID,并试图根据 URL 访问它们以获取错误的 XML 格式。
有人告诉我,Bugzilla API 不允许通过 cookie 进行访问。所以我有以下内容,但即使提供正确的用户名和密码,我也会一直卡在登录页面。这是我目前所拥有的:
pf = {'username' : 'my_username', 'password' : 'my_password' }
fields = urllib.urlencode(pf)
pageContents = StringIO.StringIO()
p = pycurl.Curl()
p.setopt(pycurl.FOLLOWLOCATION, 1)
p.setopt(pycurl.COOKIEFILE, './cookie_test.txt')
p.setopt(pycurl.COOKIEJAR, './cookie_test.txt')
p.setopt(pycurl.POST, 1)
p.setopt(pycurl.POSTFIELDS, fields)
p.setopt(pycurl.WRITEFUNCTION, pageContents.write)
p.setopt(pycurl.VERBOSE, True)
p.setopt(pycurl.DEBUGFUNCTION, test)
p.setopt(pycurl.URL, 'https://somewebsite.com/viewXMLof=[ENTER-BUG-ID-HERE]')
p.perform()
p.close() # This is mandatory.
pageContents.seek(0)
for x in pageContents.readlines() :
print x
所以我得到的显示如下:
<html lang="en">
<head>
<title>Log in to Website</title>
.
.
.
这意味着我仍在登录页面。有什么建议么?
如果需要进一步解释,请告诉我。
【问题讨论】:
标签: python xml python-2.7 bugzilla pycurl