java - 使用 Google 发布 API 上传 AAB 文件时出现 SocketTimeoutException

标签 java android google-play android-app-bundle

我正在尝试使用 Google 发布 API 上传 AAB 文件。以下是发布功能。

public void publish() throws Exception {
    String packageName = "myapp.package.name";
    String applicationName = "myApp";
    Path jsonKey = Paths.get("directory path", "secret.json");
    GoogleCredential cred = GoogleCredential.fromStream(new FileInputStream(jsonKey.toFile()));
    cred = cred.createScoped(Collections.singleton(AndroidPublisherScopes.ANDROIDPUBLISHER));
    com.google.api.services.androidpublisher.AndroidPublisher.Builder ab = new com.google.api.services.androidpublisher.AndroidPublisher.Builder(cred.getTransport(), cred.getJsonFactory(), cred);
    com.google.api.services.androidpublisher.AndroidPublisher publisher = ab.setApplicationName(applicationName).build();
    AppEdit edit = publisher.edits().insert(packageName, null).execute();
    final String editId = edit.getId();
    Path file = Paths.get("directory", "myApp.aab");
    AbstractInputStreamContent aabContent = new FileContent("application/octet-stream", file.toFile());
    Bundle bundle = publisher.edits().bundles().upload(packageName, editId, aabContent).execute();
}

我在最后一行收到以下读取超时异常:

java.net.SocketTimeoutException: Read timed out
    at java.net.SocketInputStream.socketRead0(Native Method)
    at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
    at java.net.SocketInputStream.read(SocketInputStream.java:171)
    at java.net.SocketInputStream.read(SocketInputStream.java:141)
    at sun.security.ssl.InputRecord.readFully(InputRecord.java:465)
    at sun.security.ssl.InputRecord.read(InputRecord.java:503)
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:983)
    at sun.security.ssl.SSLSocketImpl.readDataRecord(SSLSocketImpl.java:940)
    at sun.security.ssl.AppInputStream.read(AppInputStream.java:105)
    at java.io.BufferedInputStream.fill(BufferedInputStream.java:246)
    at java.io.BufferedInputStream.read1(BufferedInputStream.java:286)
    at java.io.BufferedInputStream.read(BufferedInputStream.java:345)
    at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:735)
    at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:678)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1587)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1492)
    at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:480)
    at sun.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:347)
    at com.google.api.client.http.javanet.NetHttpResponse.<init>(NetHttpResponse.java:36)
    at com.google.api.client.http.javanet.NetHttpRequest.execute(NetHttpRequest.java:144)
    at com.google.api.client.http.javanet.NetHttpRequest.execute(NetHttpRequest.java:79)
    at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:995)
    at com.google.api.client.googleapis.media.MediaHttpUploader.executeCurrentRequestWithoutGZip(MediaHttpUploader.java:548)
    at com.google.api.client.googleapis.media.MediaHttpUploader.resumableUpload(MediaHttpUploader.java:420)
    at com.google.api.client.googleapis.media.MediaHttpUploader.upload(MediaHttpUploader.java:336)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:524)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:448)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:565)

样本位于https://github.com/googlesamples/android-play-publisher-api不提供任何上传 AAB 文件的示例。你知道我缺少什么吗?

最佳答案

java.net.SocketTimeoutException: Read timed out 当 HTTP 请求超时时发生。目前 Google Http 客户端 API 中设置的默认超时为 20 秒。

Google 建议增加 HTTP 请求的超时时间 https://developers.google.com/android-publisher/api-ref/edits/bundles上传 aab 文件需要 2 分钟。

以下是如何做到这一点:

通过创建以下方法覆盖 HttpRequestInitializerinitialize 方法:

HttpRequestInitializer setHttpTimeout(final HttpRequestInitializer requestInitializer) {
    return httpRequest -> {
        requestInitializer.initialize(httpRequest);
        httpRequest.setConnectTimeout(2 * 60000);  // 2 minutes connect timeout
        httpRequest.setReadTimeout(2 * 60000);  // 2 minutes read timeout
    };
}

在实例化 AndroidPublisher.Builder 时调用 setTimeout 方法,如下所示:

com.google.api.services.androidpublisher.AndroidPublisher.Builder ab = new com.google.api.services.androidpublisher.AndroidPublisher.Builder(cred.getTransport(), cred.getJsonFactory(), setHttpTimeout(cred));

关于java - 使用 Google 发布 API 上传 AAB 文件时出现 SocketTimeoutException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56638306/

相关文章:

java - 变量应该设为 volatile 吗?

java - Spring为QueueChannel集成多线程

java - 在模块 classes.jar 中发现重复的类

c# - Xamarin keystore 丢失

android - 如何在不在支持列表中的国家/地区开发具有应用内结算功能的应用?

java - a4j 中未触发操作 :commandlink

java - 带有 @EmbeddedId 的 StackOverflowError

android - BitmapFactory.Options#outWidth 返回与实际位图不同的大小

java - 为什么 SimpleDateFormat 将 unix 日期显示为 1969 年 12 月 31 日?

android - Play 商店报告 "Your device isn' t 与此版本兼容”但它通过 adb 在 Nexus7 上安装得很好