android - CognitoCredentialsProvider 刷新时抛出 runtimeException

标签 android amazon-s3 amazon-cognito

我正在尝试从我的 Android 应用程序将文本文件上传到 Amazon s3。我正在使用 Amazon AWS 提供的以下代码 fragment 。

private static CognitoCredentialsProvider sCredProvider;

public static CognitoCredentialsProvider getCredProvider(Context context) {
    if(sCredProvider == null) {
        Log.i("Util","reached utility");
        Log.i("Util","Context"+context);
        sCredProvider = new CognitoCredentialsProvider(
                context,
                Constants.AWS_ACCOUNT_ID,
                Constants.COGNITO_POOL_ID,
                Constants.COGNITO_ROLE_UNAUTH,
                null);
        Log.i("Util","returning scredprovider"+sCredProvider);
        sCredProvider.refresh();
    }
    Log.i("Util","returning scredprovider"+sCredProvider);
    return sCredProvider;
}

当代码经过sCredProvider.refresh()时;它抛出跟随错误。

08-05 02:21:24.908: E/AndroidRuntime(25712): FATAL EXCEPTION: main
08-05 02:21:24.908: E/AndroidRuntime(25712): java.lang.RuntimeException: Unable to   create service network.NetworkService: android.os.NetworkOnMainThreadException
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.app.ActivityThread.handleCreateService(ActivityThread.java:2667)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.app.ActivityThread.access$1600(ActivityThread.java:153)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1329)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.os.Handler.dispatchMessage(Handler.java:99)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.os.Looper.loop(Looper.java:137)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.app.ActivityThread.main(ActivityThread.java:5227)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at java.lang.reflect.Method.invokeNative(Native Method)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at java.lang.reflect.Method.invoke(Method.java:511)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at dalvik.system.NativeStart.main(Native Method)
08-05 02:21:24.908: E/AndroidRuntime(25712): Caused by: android.os.NetworkOnMainThreadException
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at java.net.InetAddress.getAllByName(InetAddress.java:214)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.conn.SystemDefaultDnsResolver.resolve(SystemDefaultDnsResolver.java:45)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.conn.DefaultClientConnectionOperator.resolveHostname(DefaultClientConnectionOperator.java:278)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:162)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.conn.ManagedClientConnectionImpl.open(ManagedClientConnectionImpl.java:294)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.client.DefaultRequestDirector.tryConnect(DefaultRequestDirector.java:645)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:480)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:906)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:805)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.http.AmazonHttpClient.executeHelper(Unknown Source)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.http.AmazonHttpClient.execute(Unknown Source)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.services.cognitoidentity.AmazonCognitoIdentityServiceClient.invoke(Unknown Source)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.services.cognitoidentity.AmazonCognitoIdentityServiceClient.getOpenIdToken(Unknown Source)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.auth.CognitoCredentialsProvider.startSession(Unknown Source)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.amazonaws.auth.CognitoCredentialsProvider.refresh(Unknown Source)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at com.chan.censioevlog.Util.getCredProvider(Util.java:41)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at network.NetworkService.onCreate(NetworkService.java:55)
08-05 02:21:24.908: E/AndroidRuntime(25712):    at android.app.ActivityThread.handleCreateService(ActivityThread.java:2657)
08-05 02:21:24.908: E/AndroidRuntime(25712):    ... 10 more

注释掉该行可以正常运行应用程序。但我没有看到上传到 Amazon S3 的文件。我确实设置了 Amazon Cognito 凭证提供程序。

可以找到源代码here .

最佳答案

CognitoCredentialsProvider.refresh() 将发出网络请求以获取 Cognito 身份 ID 和 session 凭据(如果这些信息未缓存(由提供者本身处理))。根据堆栈跟踪,您在主线程上调用 getCredProvider(Context context)。并在主线程上调用 refresh() 。这就是为什么你会看到 NetworkOnMainThreadException .要解决此问题,您可以删除 sCredProvider.refresh()。如果由于某种原因你想调用 refresh(),你需要在后台线程中调用它。请引用AsyncTask .

关于android - CognitoCredentialsProvider 刷新时抛出 runtimeException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25132504/

相关文章:

android - 如何在不注册的情况下在 Android 中创建 CognitoUser?

android - 从右到左布局支持导致 xml 编辑器中出现警告 lints

android - 滚动在交错的 Gridview 中产生间隙

amazon-s3 - AWS S3 : how do I see how much disk space is using

python - 如何从 S3 存储桶 SRC 文件

amazon-web-services - 由于存储桶策略不正确,我被锁定在 S3 存储桶之外

android - iqengines 演示应用程序崩溃

android - 如何获取本地IP并显示在TextView中?

amazon-web-services - 具有 OpenAPI 规范中定义的 Cognito Authorizer 的 AWS APIGateway

java - 在 Android Studio 中使用 CognitoSyncManager