首页 > 解决方案 > Azure 分析休息 api:401 未经授权。“身份验证失败。”

问题描述

我正在尝试按照此 azure 文档进行数据分区刷新(发布):https ://docs.microsoft.com/en-us/azure/analysis-services/analysis-services-async-refresh

无论是邮寄还是获得我都得到 401 Unauthorized (即使服务关闭!)。

我从 azure AD (ServicePrincipalCredential) 获得了令牌。我将 AD 添加为 Analysis Services 管理员 ( https://docs.microsoft.com/en-us/azure/analysis-services/analysis-services-server-admins ) 我在 Analysis Services IAM 中将所有者角色赋予了 AD。

它与 Analysis Services 管理 rest api ( https://docs.microsoft.com/en-us/rest/api/analysisservices/operations/list ) 使用相同的身份验证 (得到代码响应 200)

我的python代码:

from azure.common.credentials import ServicePrincipalCredentials
import requests

credentials = ServicePrincipalCredentials(client_id="ad_client_id",
                                          secret="ad_secret",
                                          tenant="ad_tenant")
token = credentials.token

url = "https://westeurope.asazure.windows.net/servers/{my_server}/models/{my_model}/refreshes"

test_refresh = {
            "Type": "Full",
            "CommitMode": "transactional",
            "MaxParallelism": 1,
            "RetryCount": 1,
            "Objects": [
                {
                    "table": "my_table",
                    "partition": "my_partition"
                }
            ]
        }

header={'Content-Type':'application/json', 'Authorization': "Bearer {}".format(token['access_token'])}

r = requests.post(url=url, headers=header, data=test_refresh)

import json
print(json.dumps(r.json(), indent=" "))

我得到的回应:

{
 "code": "Unauthorized",
 "subCode": 0,
 "message": "Authentication failed.",
 "timeStamp": "2019-05-22T13:39:03.0322998Z",
 "httpStatusCode": 401,
 "details": [
  {
   "code": "RootActivityId",
   "message": "aab22348-9ba7-42c9-a317-fbc231832f75"
  }
 ]
}

我很绝望,你能帮我澄清一下吗?

标签: pythonazurerestapiazure-analysis-services

解决方案


最后我解决了这个问题。我有错误的令牌。该 api 需要一个 OAuth2.0 身份验证令牌(Azure 分析服务其余 api 文档不太清楚如何获得一个)

对于那些会遇到相同问题的人,有办法获得一个。

from adal import AuthenticationContext

authority = "https://login.windows.net/{AD_tenant_ID}"
auth_context = AuthenticationContext(authority)
oauth_token = auth_context.acquire_token_with_client_credentials(resource="https://westeurope.asazure.windows.net", client_id=AD_client_id, client_secret=AD_client_id)
token = oauth_token['accessToken']

关于此的文档: https ://docs.microsoft.com/en-us/python/api/adal/adal.authentication_context.authenticationcontext?view=azure-python#acquire-token-with-client-credentials-resource--client -id--client-secret-

https://github.com/AzureAD/azure-activedirectory-library-for-python/wiki/ADAL-basics


推荐阅读