通过API

时间:2017-10-28 21:14:53

标签: python github python-requests github-api

我正在尝试在我公司的企业github服务器上下载一个repo版本。我有一个带有OAuth令牌的正确授权标头,并且能够获得版本端点的响应。这个特殊的repo有源代码的zip和tarball以及编译的可执行文件。构建的可执行文件是我试图下载的。发布请求的响应如下所示,browser_download_url密钥中的assets键是您感兴趣的。

{
    "url": "***/releases/1491",
    "assets_url": "***/releases/1491/assets",
    "upload_url": "***/releases/1491/assets{?name,label}",
    "html_url": "***/releases/tag/1.0.6",
    "id": 1491,
    "tag_name": "1.0.6",
    "target_commitish": "release-1.0.6",
    "name": "1.0.6",
    "draft": false,
    "prerelease": true,
    "created_at": "2017-10-03T15:51:25Z",
    "published_at": "2017-10-10T16:54:16Z",
    "assets": [
        {
            "url": "***/releases/assets/53",
            "id": 53,
            "name": "<program>.exe",
            "label": null,
            "content_type": "application/x-msdownload",
            "state": "uploaded",
            "size": 36023208,
            "download_count": 10,
            "created_at": "2017-10-10T17:40:32Z",
            "updated_at": "2017-10-10T17:40:32Z",
            "browser_download_url": "***/1.0.6/<program>.exe"
        }
    ],
    "tarball_url": "***/tarball/1.0.6",
    "zipball_url": "***/zipball/1.0.6",
    "body": "<description of release>"
}

然而,当我尝试请求browser_download_url时,我会在响应内容中获取登录页面的html,因为它正在寻找进一步的身份验证。

response = session.get(release_endpoint_response.json()['assets'][0]['browser_download_url'], headers={'Authorization': 'token <personal_access_token>'}) 

我的问题是,有没有办法从这个链接下载而无需明确登录并只使用令牌和标题?
最好的方法是什么? 是否有任何包装或库可以帮助我以不同的方式实现这一目标?  很有责任!

编辑:此外,应该注意的是,在请求tarball和zip urls时,压缩的源代码文件下载正常。这里的问题是我有一个不合适的构建环境,所以我希望下载可执行文件。有趣的是,我没有像使用构建exe那样使用拉链的身份验证问题。

1 个答案:

答案 0 :(得分:1)

我相信找到了解决方案here。基本上我需要获取所需版本的资产ID,然后将Accept标头包含为application / octet-stream。只需在发布端点中获取所需的任何版本的资产ID,设置标题然后点击此端点:/repos/:owner/:repo/releases/assets/:id

编辑:这对我有用。被标记为答案=)