我有使用 Google Docs API 的应用程序。直到最近,使用 HTTP 端点的上传一直运行良好。最近上传突然开始报错。第一次调用创建会话(返回可恢复的 URL)工作正常,并返回可恢复的 URL。然后尝试将文件内容发送到可恢复 URL 会引发 503。
引发错误的代码的相关部分是这样的:
URL url = new URL(resumableFileUploadUrl);
conn = (HttpURLConnection) url.openConnection();
conn.addRequestProperty("client_id", OAuth2Client.CLIENT_ID);
conn.addRequestProperty("client_secret", OAuth2Client.CLIENT_SECRET);
conn.setRequestProperty("Authorization", "OAuth " + GetAuthToken());
conn.setRequestProperty("X-Upload-Content-Length", String.valueOf(fileContents.length())); //back to 0
conn.setRequestProperty("X-Upload-Content-Type", "text/xml");
conn.setRequestProperty("Content-Type", "text/xml");
conn.setRequestProperty("Content-Length", String.valueOf(fileContents.length()));
conn.setRequestProperty("Slug", fileName);
if(isUpdate)
{
conn.setRequestProperty("If-Match", "*");
conn.setRequestMethod("PUT");
}
else
{
conn.setRequestMethod("POST");
}
conn.setRequestProperty("GData-Version", "3.0");
conn.setRequestProperty("User-Agent", "GPSLogger for Android");
conn.setUseCaches(false);
conn.setDoInput(true);
conn.setDoOutput(true);
DataOutputStream wr = new DataOutputStream(
conn.getOutputStream());
wr.writeBytes(fileContents);
wr.flush();
wr.close();
int code = conn.getResponseCode();
newLocation = conn.getHeaderField("location");
上面的代码用于创建会话以获取可恢复 URL 以及将文件内容发布到可恢复 URL。
这是此Android 活动的一部分。我包含一个指向原始活动的链接,因为只需克隆存储库就可以很容易地重现问题。代码一年没有动过。
最近有什么变化会导致这种情况吗?
我想暂时避免使用 Google Drive 的 API,因为我没有更改任何代码,并且我在该领域的其他一些应用程序中使用了相同的代码。