0

我有这个完美运行的 cURL 调用:

curl -H 'X-Requested-With: SO demo' -d 'parameter=value' https://username:password@api.domain.com/api/work/

我的转换不起作用。

import urllib2
# Create a password manager.
password_mgr = urllib2.HTTPPasswordMgrWithDefaultRealm()
# Add the username and password.
top_level_url = 'https://api.server.com'
password_mgr.add_password(None, top_level_url, 'username', 'password')
handler = urllib2.HTTPBasicAuthHandler(password_mgr)
# Create "opener" (OpenerDirector instance).
opener = urllib2.build_opener(handler)
# Install the opener so all calls to urllib2.urlopen use our opener.
urllib2.install_opener(opener)
# Create request.
headers = {'X-Requested-With':'SO demo.'}
uri = 'https://api.domain.com/api/work/'
data='parameter=value'
req = urllib2.Request(uri,data,headers)
# Make request to fetch url.
result = urllib2.urlopen(req)
urllib2.HTTPError: HTTP Error 401: Unauthorized

这是我不明白的。同一台服务器有一个单独的 API,类似的代码可以在其中工作,唯一改变的是参数和 uri。请注意,cURL 调用适用于两个 API 调用。

第二个 API cURL 调用(有效):

curl -H 'X-Requested-With: SO demo' -d 'parameter=value' https://username:password@api.domain.com/api2/call.php

在下面工作的等效代码:

import urllib2
# Create a password manager.
password_mgr = urllib2.HTTPPasswordMgrWithDefaultRealm()
# Add the username and password.
top_level_url = 'https://api.server.com'
password_mgr.add_password(None, top_level_url, 'username', 'password')
handler = urllib2.HTTPBasicAuthHandler(password_mgr)
# Create "opener" (OpenerDirector instance).
opener = urllib2.build_opener(handler)
# Install the opener.
# Now all calls to urllib2.urlopen use our opener.
urllib2.install_opener(opener)
# Create request.
headers = {'X-Requested-With':'SO demo.'}
uri = 'https://api.server.com/api2/call.php'
data='parameter=value'
req = urllib2.Request(uri,data,headers)
# Make request to fetch url.
result = urllib2.urlopen(req)
# Read results.
result.read()

为什么当 uri 以 '.php' 结尾时 urllib2 有效,但当uri 以 '/' 结尾时无效

4

2 回答 2

2

在您设置的第一个请求中:

uri = 'https://api.domain.com/api/work/'

但是如果你要像第二次运行一样做,你可能打算把它写成:

uri = 'https://api.server.com/api/work/'
于 2012-01-28T03:29:12.870 回答
1

来自Python urllib2 基本身份验证问题

问题 [是] Python 库,根据 HTTP 标准,首先发送一个未经身份验证的请求,然后只有当它被 401 重试回答时,才会发送正确的凭据。如果 ... 服务器不执行“完全标准的身份验证”,那么这些库将无法工作。

此特定 API 在第一次尝试时不会以 401 重试响应,它会以包含未发送凭据的消息的 XML 响应进行响应。

于 2012-03-02T20:32:16.393 回答