6

我正在使用 2018 版的 Google Photos API 上传图像和媒体,如下所述:“上传字节

当我上传图像或视频时,我从未在响应正文中获得上传令牌。它始终是一个空正文,根据上面的链接,这意味着字节已经上传(但这是一个新的上传)。

这是一个示例请求/响应:

request: 
    POST https://photoslibrary.googleapis.com/v1/uploads
request headers: 
    authorization: Bearer abcd1234
    X-Goog-Upload-Protocol: raw
    X-Goog-Upload-File-Name: 20140317T082917_001.jpg
    content-type: application/octet-stream
    content-length: 1292868
    accept: application/json
-----------------------------------------------------
response: OK [200]
response headers:
    Alt-Svc: [quic=":443"; ma=2592000; v="44,43,39,35"]
    Server: [UploadServer]
    X-GUploader-UploadID: [AEnB2UqT6y8KyZNCPyAaFeCj7I_ABIlwLJQMpltYzQ7D8blW4v3uKSlMT7dbNjFV0i_7ApzoR-i26ZtZ9kHkB7bI8n8ojgOnNA]
    Content-Length: [510]
    Date: [Sun, 05 Aug 2018 11:19:15 GMT]
    Content-Type: [text/plain]
response body:
    null

我也尝试过使用X-GUploader-UploadID标头中返回的值,但这会导致500错误。

有人可以提供一个如何将字节上传到 Google Photos API 的工作示例吗?

谢谢!

4

3 回答 3

2

我认为您只是没有查看响应内容。以下适用于 Python,当然您也可以使其适用于 Java:

def upload_files(self, filepath, album_id):
    filename = os.path.basename(filepath)
    url = 'https://photoslibrary.googleapis.com/v1/uploads'
    authorization = 'Bearer ' + creds.access_token

    headers = {
        "Authorization": authorization,
        'Content-type': 'application/octet-stream',
        'X-Goog-Upload-File-Name': filename,
        'X-Goog-Upload-Protocol': 'raw',
    }
    with open(filepath, "rb") as image_file:
        response = requests.post(url, headers=headers, data=image_file)
        assert response.status_code == 200
        token = response.text  # !!!
    return service.mediaItems().batchCreate(body=dict(
        albumId=album_id,
        newMediaItems=[
            {"simpleMediaItem": {"uploadToken": token}}]
    )).execute()
于 2018-08-27T11:13:51.190 回答
1

这对我有用,以下方法中返回的 r.content 包含上传令牌,您需要将其传递给 MediaItems:batchCreate API 调用,以便在用户的库中创建媒体:

def upload(your_access_token, your_media_path):
item = open(your_media_path, 'rb').read()
url = 'https://photoslibrary.googleapis.com/v1/uploads'
headers = {
    'Authorization': 'Bearer ' + token,
    'Content-Type': 'application/octet-stream',
    'X-Goog-Upload-File-Name': 'image1.jpg',
    'X-Goog-Upload-Protocol': 'raw',
}

r = requests.post(url, data = item, headers = headers)
return r.content.decode('utf-8')
于 2019-04-26T22:33:26.967 回答
1

实际上,您确实得到了响应正文。如果你看你的回复

response: OK [200]
response headers:
    Alt-Svc: [quic=":443"; ma=2592000; v="44,43,39,35"]
    Server: [UploadServer]
    X-GUploader-UploadID: [AEnB2UqT6y8KyZNCPyAaFeCj7I_ABIlwLJQMpltYzQ7D8blW4v3uKSlMT7dbNjFV0i_7ApzoR-i26ZtZ9kHkB7bI8n8ojgOnNA]
    Content-Length: [510]
    Date: [Sun, 05 Aug 2018 11:19:15 GMT]
    Content-Type: [text/plain]
response body:
    null

有一个字段Content-Length指示正文的字节长度,在您的情况下为 510。您使用哪种方法获取此信息?你目前的实施是什么?

如果您只尝试通过例如通过curl然后我实际上不知道为什么没有响应主体,但是它不适合 java 标记的范围,所以我假设您自己解析了响应在一些自写的java代码中?

因为您没有提供它,所以这只是猜测,但我假设您在解析响应时错过了一些东西。

于 2019-04-12T09:16:13.443 回答