Android Azure SDK - 当我尝试从 Blob 存储加载内容时出现 NullPointerException

标签 android azure azure-mobile-services

我在 Azure 上创建了一个名为“assetcontainer”的容器。

我按照示例创建了以下代码:

 CloudStorageAccount account = CloudStorageAccount.parse(BuildConfig.AzureConnectionString);
        mClient = account.createCloudBlobClient();
        mAssetContainer = mClient.getContainerReference("assetcontainer");


        // Download the blob
        // For each item in the container
        for (ListBlobItem blobItem : mAssetContainer.listBlobs()) {
            // If the item is a blob, not a virtual directory
            if (blobItem instanceof CloudBlockBlob) {
                // Download the text
                CloudBlockBlob retrievedBlob = (CloudBlockBlob) blobItem;

                try {
                    retrievedBlob.download(new FileOutputStream(mContext.getFilesDir() + "\\assets\\" + ((CloudBlockBlob) blobItem).getName()));
                }
                catch(Exception ex){}
            }
        }

当我尝试迭代 listBlobs() 时,我收到以下异常:

Process: com.training.app.debug, PID: 3284
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.training.app.debug/com.training.app.activities.MainActivity}: java.lang.NullPointerException
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2292)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2350)
            at android.app.ActivityThread.access$800(ActivityThread.java:163)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1257)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:157)
            at android.app.ActivityThread.main(ActivityThread.java:5335)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.NullPointerException
            at com.android.okhttp.internal.http.HttpEngine.readResponse(HttpEngine.java:783)
            at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:347)
            at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:296)
            at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:503)
            at com.microsoft.azure.storage.StorageException.translateException(StorageException.java:145)
            at com.microsoft.azure.storage.core.ExecutionEngine.executeWithRetry(ExecutionEngine.java:252)
            at com.microsoft.azure.storage.core.LazySegmentedIterator.hasNext(LazySegmentedIterator.java:109)
            at com.training.azure.AzureStorage.syncAssets(AzureStorage.java:57)
            at com.training.app.activities.MainActivity.onCreate(MainActivity.java:52)
            at android.app.Activity.performCreate(Activity.java:5389)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2256)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2350)
            at android.app.ActivityThread.access$800(ActivityThread.java:163)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1257)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:157)
            at android.app.ActivityThread.main(ActivityThread.java:5335)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
            at dalvik.system.NativeStart.main(Native Method)

我不确定这里出了什么问题...这是 azure sdk 的错误吗?

最佳答案

我从 this page 找到了解决方案,这对我有用。

Android不允许在主线程中执行网络操作,因此需要在异步任务中执行代码,如下所示:

private class MyTask extends AsyncTask<Void, Void, Void>{
 @Override
protected Void doInBackground(Void... params) {
    CloudStorageAccount account = CloudStorageAccount.parse(BuildConfig.AzureConnectionString);
    mClient = account.createCloudBlobClient();
    mAssetContainer = mClient.getContainerReference("assetcontainer");


    // Download the blob
    // For each item in the container
    for (ListBlobItem blobItem : mAssetContainer.listBlobs()) {
        // If the item is a blob, not a virtual directory
        if (blobItem instanceof CloudBlockBlob) {
            // Download the text
            CloudBlockBlob retrievedBlob = (CloudBlockBlob) blobItem;

            try {
                retrievedBlob.download(new FileOutputStream(mContext.getFilesDir() + "\\assets\\" + ((CloudBlockBlob) blobItem).getName()));
            }
            catch(Exception ex){}
        }
    }
}
}

然后在主线程中调用new MyTask().execute()

关于Android Azure SDK - 当我尝试从 Blob 存储加载内容时出现 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24813230/

相关文章:

java - 使用 Firestore 管理 Android 后台堆栈和监听器以优化文档读取

android - 如何在布局的一角放置徽章图标

deployment - 在单个实例中部署 Web 角色和辅助角色

c# - Azure 移动服务 Active Directory 身份验证 X-ZUMO-AUTH token 在注销后在 postman 中有效

android - 无法更改 TabLayout 中的选项卡

android - 在自定义 ViewGroup 子类中调整旋转 subview 的大小

powershell - 无法识别术语 'Add-AzureAccount'

Azure队列: find whether item is in queue

ios - 尝试与 Azure 移动服务同步时出现 IMobileServiceClient.PullAsync 死锁

Xamarin 中缺少 Azure 移动服务 InvokeApi