【发布时间】:2020-02-23 20:04:55
【问题描述】:
我已经从 Azure Devops 用户界面生成了一个个人访问令牌,但我无法使用它来向 Devops API 发出请求。
我尝试了许多不同的标头字段,但我总是被重定向到登录页面,就好像我没有经过身份验证一样。
token = #Token generated on Devops project page
token_bytes = token.encode('utf-8')
token64 = base64.b64encode(token_bytes)
authorization_string = "basic " + str(token64)
repo_endpoint_url = "https://dev.azure.com/{organization}/{project}/_apis/git/repositories?api-version=5.1".format(organization=organization, project=project)
headers = {"Content-Type" : "application/json", "Authorization" : authorization_string}
response = requests.get(repo_endpoint_url, headers)
响应总是 203 与登录页面 HTML。如果标题中没有访问令牌,这就是我希望看到的。
我试过用“Bearer”代替“basic”,我试过添加 {username}:{token} 和许多其他的小调整。
我做错了什么?
【问题讨论】:
-
很高兴看到在我的令牌前面添加一个冒号是一个潜在的修复,但遗憾的是它对我的脚本的运行没有任何影响。我仍然收到 203 响应,其中包含 html 提示登录详细信息
-
您是否也进行了
base64编码? -
您为 PAT 提供了哪个范围?
-
@ycx 是的。我在重新输入代码时遗漏了一行(无法从 VM 复制并粘贴到我的本地),但我使用的是上面更新的 base64 python 包
标签: python request azure-devops access-token azure-devops-rest-api