1

我想调用 PowerBI rest api 调用以从本地/特定存储库上传 pbix 文件。

  • 我应该如何生成不记名令牌以从邮递员那里获得授权?

  • 这个 rest api 调用会生成令牌吗?

  • 这个休息调用需要传递什么作为授权令牌?

  • myorg 是 PowerBI 帐户名吗?从哪里可以获取 myorg 值?

     POST https://api.powerbi.com/v1.0/myorg/GenerateToken
    

下面是我想通过邮递员调用的更多电话:

GET https://api.powerbi.com/v1.0/myorg/imports
GET https://api.powerbi.com/v1.0/myorg/reports/{reportId}

也很少打电话。

生成令牌的快速解决方案是什么?

4

1 回答 1

0

您可以使用此功能请求访问

必须在 azure https://docs.microsoft.com/en-us/power-bi/developer/embedded/register-app?tabs=customers%2CAzure中创建客户端 ID

    application_id= 'None'
    application_secret= 'None'
    user_id= 'None'
    user_password= 'None'

    accessToken = None 
    requestHeaders = None 
    tokenExpiry = None 
    accessToken_AD = None 
    requestHeaders_AD = None 
    tokenExpiry_AD = None 

     def pbi_auth(application_id,application_secret,user_id,user_password):
        global accessToken
        global requestHeaders
        global tokenExpiry
        data = {
            'grant_type': 'password',
            'scope': 'openid',
            'resource': "https://analysis.windows.net/powerbi/api",
            'client_id': application_id,
            'client_secret': application_secret,
            'username': user_id,
            'password': user_password
        }
        token = requests.post("https://login.microsoftonline.com/common/oauth2/token", data=data)
        assert token.status_code == 200, "Fail to retrieve token: {}".format(token.text)
        #print("Got access token: ")
        #print(token.json())
        accessToken = token.json()['access_token']
    
        requestHeaders= {
            'Content-Type': 'application/json; charset=utf-8',
            'Authorization': "Bearer {}".format(accessToken)
        }

    pbi_auth(application_id,application_secret,user_id,user_password)
    reportId= ""
    URI = "https://api.powerbi.com/v1.0/myorg/reports/{}".format(reportId)
    queryResults =  requests.get(URI, headers=requestHeaders)
于 2021-08-12T13:40:24.253 回答