openstack无法从API检索身份验证令牌

时间:2018-07-03 11:10:53

标签: python openstack

我正在尝试使用python的请求库从API检索身份验证令牌。这是我到目前为止所做的尝试:

def get_token():
    data = { 
      "auth" : {
         "identity" : { 
            "methods" : [ "password" ],
            "password": { 
               "user" : { 
                  "name"  : OS_USERNAME,
                  "domain": { "name": "Default" },
                  "password": OS_PASSWORD
               }
            }
         }
      }   
    }

    r = requests.post(
    OS_AUTH_URL+'/auth/tokens',
      headers = HEADERS,
      json    = data,      # https://stackoverflow.com/questions/9733638
      verify  = False
    )
    print(r.content)
    j = json.loads(r.content)
    return j['token']['user']['id']

我在响应中得到令牌:

{
  "token": {
    "issued_at": "2018-07-03T11:03:59.000000Z",
    "audit_ids": [
      "Fg1ywtZBQ1CkigCw70If9g"
    ],
    "methods": [
      "password"
    ],
    "expires_at": "2018-07-03T12:03:59.000000Z",
    "user": {
      "password_expires_at": null,
      "domain": {
        "id": "default",
        "name": "Default"
      },
      "id": "e0dc5beb383a46b98dad824c5d76e719",
      "name": "admin"
    }
  }
}

但是,当我重用此令牌以获取例如项目列表时:

def get_tenantID():
  r = requests.get(
    OS_AUTH_URL+'/auth/projects',
    headers = HEADERS,
    verify  = False
  )
return r
r = get_token()
HEADERS['X-Auth-Project-Id'] = 'admin'
HEADERS['X-Auth-Token'] = r
r = get_tenantID()

我收到此错误,好像我无法通过身份验证一样:

<Response [401]>
{"error": {"message": "The request you have made requires authentication.", "code": 401, "title": "Unauthorized"}}

在谷歌上搜索并使用openstack token issue命令通常会发现令牌更像是:

 gAAAAABaCo1F1CIMVlsTBeuqYH8tm2qR29tbkmUL4vZuhCNPXJI39TQ2YzL6Twoj8fNcAyLe3WhCYW2O1YpbBF0G8mo4bt7Kf0IRsoDOoJ6uWa3RYyJ5SQNoB_5n8EnVXbKPxFYOZ_iFBnaVtL1_XDrGbwsrlDeyy8lZTDdLsqY52pUhFR-7Uow

这不是我用get_token得到的。

我在做什么错了?

非常感谢!

2 个答案:

答案 0 :(得分:2)

直接使用auth API时,发出的令牌位于X-Subject-Token标头中。

因此,要在您的python示例中进行检索,您可以像这样访问response.headers字典:

token = r.headers['X-Subject-Token']

有关Keystone v3 docs中认证的更多信息

答案 1 :(得分:0)

1. fetch authentication token as mentioned below: 
 r = requests.post(
 OS_AUTH_URL+'/auth/tokens',
  headers = HEADERS,
  json    = data,     
  verify  = False
 )
 token = r.headers[X-Subject-Token] 

2. Pass this token in header for further request:
 {
        'X-Auth-Token': token
    }