3

我正在尝试从 Sabre Dev Studio 获取身份验证令牌。我遵循此处给出的通用说明https://developer.sabre.com/docs/read/rest_basics/authentication(需要登录才能查看),但我无法弄清楚如何使用 Python 获取令牌 - 特别是使用 python- oauth2 库,因为似乎建议简化该过程。

这是我的代码示例:

config = ConfigParser.ConfigParser()
config.read("conf.ini")
clientID = config.get('DEV', 'Key').strip()
clientSecret = config.get('DEV', 'SharedSecret').strip()

consumer = oauth.Consumer(key=base64.b64encode(clientID), 
                          secret=base64.b64encode(clientSecret))

# Request token URL for Sabre.
request_token_url = "https://api.sabre.com/v1/auth/token"

# Create our client.
client = oauth.Client(consumer)

# create headers as per Sabre Dev Guidelines https://developer.sabre.com/docs/read/rest_basics/authentication
headers = {'Content-Type':'application/x-www-form-urlencoded'}
params = {'grant_type':'client_credentials'}

# The OAuth Client request works just like httplib2 for the most part.
resp, content = client.request(request_token_url, "POST", headers=headers)

print resp
print content

响应为 401 类型。凭据不完整或格式错误。任何建议表示赞赏。

4

3 回答 3

1

我不能用 oauth2,但我用 requests 包我想你可以从这里得到它

我的代码是:

import requests
import base64
import json


def encodeBase64(stringToEncode):
    retorno = ""
    retorno = base64.b64encode(stringToEncode)    
    return retorno


parameters = {"user": "YOUR_USER", "group": "YOUR_GROUP", "domain": "YOUR_DOMAIN", "password": "YOUR_PASSWORD"}

endpoint = "https://api.test.sabre.com/v1"

urlByService = "/auth/token?="
url = endpoint + urlByService
user = parameters["user"]
group = parameters["group"]
domain = parameters["domain"]
password = parameters["password"]
encodedUserInfo =  encodeBase64("V1:" + user + ":" + group + ":" + domain)
encodedPassword =  encodeBase64(password)
encodedSecurityInfo = encodeBase64(encodedUserInfo + ":" + encodedPassword)
data = {'grant_type':'client_credentials'}
headers = {'content-type': 'application/x-www-form-urlencoded ','Authorization': 'Basic ' + encodedSecurityInfo}

response = requests.post(url, headers=headers,data=data)

print "Post Request to: " + url
print response
print "Response Message: " + response.text

问候,

于 2014-07-17T19:46:56.897 回答
1

首先获取您的凭据:

  1. https://developer.sabre.com/member/register中注册
  2. 登录https://developer.sabre.com
  3. 转到https://developer.sabre.com/apps/mykeys并获取您的凭据。它们应该看起来像这样(垃圾邮件和鸡蛋看起来像垃圾):

    client_id = 'V1:spam:DEVCENTER:EXT'
    client_secret = 'eggs'
    

然后调用/v2/auth/token端点以获取访问令牌:

import requests
credentials = ":".join([part.encode('base64').strip() 
                        for part in (client_id, client_secret)]
                 ).encode('base64').strip()

url = 'https://api.test.sabre.com/v2/auth/token'
headers = {'Authorization': 'Basic ' + credentials}
params = {'grant_type': 'client_credentials'}

r = requests.post(url, headers=headers, data=params)
assert r.status_code is 200, 'Oops...'
token = r.json()
print(token)

你应该得到这样的东西:

{u'access_token': u'T1RLAQJwPBoAuz...x8zEJg**', 
 u'token_type': u'bearer', 
 u'expires_in': 604800}

Authorization现在,您可以使用包含访问令牌的标头调用其他端点。例如,如果您想要支持的国家/地区列表:

headers = {'Authorization': 'Bearer ' + token[u'access_token']}
endpoint = 'https://api.test.sabre.com/v1/lists/supported/countries'
r = requests.get(endpoint, headers=headers)
assert r.status_code is 200, 'Oops...'

print (r.json())

如果一切顺利,您应该会收到支持的国家/地区列表:

{u'DestinationCountries': [
   {u'CountryName': u'Antigua And Barbuda', u'CountryCode': u'AG'}, 
   {u'CountryName': u'Argentina', u'CountryCode': u'AR'}, 
   {u'CountryName': u'Armenia', u'CountryCode': u'AM'}, 
   {u'CountryName': u'Aruba', u'CountryCode': u'AW'},
   ...
}
于 2015-08-29T01:49:22.383 回答
0

我很确定您正在使用这个 oauth 库:https ://pypi.python.org/pypi/oauth2 尽管被命名为“oauth2”,但它并没有实现 OAuth 2 规范。这是我能找到的最好的库,它提供 OAuth 2 支持并有文档:http ://requests-oauthlib.readthedocs.org/en/latest/oauth2_workflow.html

于 2015-10-06T17:54:08.037 回答