Произошло исключение StorageException. Невозможно загрузить изображения в FireBase - PullRequest
0 голосов
/ 05 мая 2018

Этот код работал до того, как я смог изменить изображение и загрузить его в FireBase, но внезапно я получаю эту ошибку сейчас, я не знаю, в чем проблема, кажется.

public class SettingsActivity extends AppCompatActivity {
    private static final int MAX_LENGTH = 100;
    private FirebaseUser mFireBaseUser;
    private DatabaseReference mDatabaseReference;
    private TextView display;
    private TextView c_status, id;
    private ImageView proPic;
    private Button changeStatus, changePic;
    private static final int GALLERY_PIC = 1;
    private StorageReference mStorage;
    private ProgressDialog mProgressBar;

    private DatabaseReference onlineDatabase;
    private FirebaseUser current;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_settings);

        mFireBaseUser = FirebaseAuth.getInstance().getCurrentUser();
        String uId = mFireBaseUser.getUid();
        mDatabaseReference = FirebaseDatabase.getInstance().getReference().child("users").child(uId);

        mStorage = FirebaseStorage.getInstance().getReference();

        mProgressBar = new ProgressDialog(this);

        display = findViewById(R.id.setting_displayName);
        c_status = findViewById(R.id.setting_status);
        proPic = findViewById(R.id.setting_image);
        changeStatus = findViewById(R.id.setting_changeStatusButton);
        changePic = findViewById(R.id.setting_changeImageButton);
        id = findViewById(R.id.setting_displayId);

        current = FirebaseAuth.getInstance().getCurrentUser();
        onlineDatabase = FirebaseDatabase.getInstance().getReference().child("users").child(current.getUid()).child("Online");

        mDatabaseReference.addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                String name = dataSnapshot.child("Name").getValue().toString();
                String image = dataSnapshot.child("Image").getValue().toString();
                String status = dataSnapshot.child("Status").getValue().toString();
                final String thumbImage = dataSnapshot.child("Thumb_image").getValue().toString();
                String v_id = dataSnapshot.child("Id").getValue().toString();

                display.setText(name);
                c_status.setText(status);
                id.setText(v_id);

                if(!thumbImage.equals("default")) {
                    Picasso.with(SettingsActivity.this).load(thumbImage).placeholder(R.drawable.avatar_default).into(proPic);
                    }

                proPic.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View v) {
                        Intent intent = new Intent(getApplication(), FullScreenImageView.class);
                        intent.setType(thumbImage);
                        startActivity(intent);
                    }
                });

            }

            @Override
            public void onCancelled(DatabaseError databaseError) {

            }
        });

        changeStatus.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                startActivity(new Intent(SettingsActivity.this, ChangeStatus.class));
            }
        });

        changePic.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent gallery = new Intent();
                gallery.setType("image/*");
                gallery.setAction(Intent.ACTION_GET_CONTENT);
                startActivityForResult(Intent.createChooser(gallery, "SELECT IMAGE"), GALLERY_PIC);

            }
        });


    }
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data){
        super.onActivityResult(requestCode, resultCode, data);


        if(requestCode == GALLERY_PIC && resultCode == RESULT_OK){
            Uri imageUri = data.getData();
            CropImage.activity(imageUri)
                    .setAspectRatio(1, 1)   
                    .start(this);
        }

        if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE) {
            CropImage.ActivityResult result = CropImage.getActivityResult(data);

            if (resultCode == RESULT_OK) {

                mProgressBar.setTitle("Uploading Image");
                mProgressBar.setMessage("Please wait while we uploading the image and process...");
                mProgressBar.setCanceledOnTouchOutside(false);
                mProgressBar.show();

                Uri resultUri = result.getUri();  
                String uId = mFireBaseUser.getUid();

                File thumb_filePath = new File(resultUri.getPath());
                Bitmap thumb_bitmap = new Compressor(this)
                        .setMaxWidth(1000)
                        .setMaxHeight(1000)
                        .setQuality(1000)
                        .compressToBitmap(thumb_filePath);

                //for uploading thumb image to database

                ByteArrayOutputStream baos = new ByteArrayOutputStream();
                thumb_bitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos);
                final byte[] thumb_byte = baos.toByteArray();

                StorageReference store = mStorage.child("Profile picture").child(uId + ".jpg");     // random() er bodole "uId" likhle valo hobe.
                final StorageReference thumb_store = mStorage.child("Profile picture").child("Thumb").child(uId + ".jpg");

                store.putFile(resultUri).addOnCompleteListener(new OnCompleteListener<UploadTask.TaskSnapshot>() {
                    @Override
                    public void onComplete(@NonNull Task<UploadTask.TaskSnapshot> task) {
                        if(task.isSuccessful()){

                            final String download_url = task.getResult().getDownloadUrl().toString();

                            UploadTask uploadTask = thumb_store.putBytes(thumb_byte);

                            uploadTask.addOnCompleteListener(new OnCompleteListener<UploadTask.TaskSnapshot>() {
                                @Override
                                public void onComplete(@NonNull Task<UploadTask.TaskSnapshot> thumb_task) {

                                    String download_thumb_url = thumb_task.getResult().getDownloadUrl().toString();

                                    if(thumb_task.isSuccessful()) {

                                        Map updateHashMap = new HashMap();      //    Map <String, String> likhle hobe na.
                                        updateHashMap.put("Image", download_url);
                                        updateHashMap.put("Thumb_image", download_thumb_url);

                                        mDatabaseReference.updateChildren(updateHashMap).addOnCompleteListener(new OnCompleteListener<Void>() {
                                            @Override
                                            public void onComplete(@NonNull Task<Void> task) {
                                                if(task.isSuccessful()) {
                                                    mProgressBar.dismiss();
                                                    Toast.makeText(SettingsActivity.this, "Uploaded", Toast.LENGTH_LONG).show();
                                                }
                                                else{
                                                    mProgressBar.dismiss();
                                                    Toast.makeText(SettingsActivity.this, "Error", Toast.LENGTH_LONG).show();
                                                }
                                            }
                                        });
                                    }
                                    else{

                                    }
                                }
                            });
                        }
                        else{
                            mProgressBar.dismiss();
                            Toast.makeText(SettingsActivity.this, "Error", Toast.LENGTH_LONG).show();
                        }
                    }
                });

            } else if (resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE) {
                Exception error = result.getError();
            }
        }

    }

    @Override
    public void onResume() {
        super.onResume();
        onlineDatabase.setValue("true");
    }

    @Override
    public void onPause() {
        super.onPause();
        onlineDatabase.setValue(ServerValue.TIMESTAMP);
    }

}

Это мой профиль с простым изображением и двумя кнопками. Когда я пытаюсь изменить свое изображение профиля, я получаю следующую ошибку.

    I/DynamiteModule: Considering local module com.google.android.gms.firebasestorage:0 and remote module com.google.android.gms.firebasestorage:6
I/DynamiteModule: Selected remote version of com.google.android.gms.firebasestorage, version >= 6
W/System: ClassLoader referenced unknown path: /data/user_de/0/com.google.android.gms/app_chimera/m/00000039/DynamiteModulesC_GmsCore_prodmnc_xhdpi_release.apk
W/System: ClassLoader referenced unknown path: /data/user_de/0/com.google.android.gms/app_chimera/m/00000039/DynamiteModulesC_GmsCore_prodmnc_xhdpi_release.apk
E/ChimeraFileApk: Failed to validate DexClassLoader.
                  java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.chimera.DynamiteModuleInitializer" on path: DexPathList[[],nativeLibraryDirectories=[/system/lib, /vendor/lib, /system/vendor/lib, /product/lib]]
                      at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
                      at java.lang.ClassLoader.loadClass(ClassLoader.java:380)
                      at ddb.loadClass(:com.google.android.gms@12673021@12.6.73 (040306-194189626):3)
                      at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
                      at day.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):22)
                      at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):84)
                      at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):52)
                      at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):117)
                      at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):114)
                      at ryk.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):13)
                      at com.google.android.gms.chimera.container.DynamiteLoaderImpl.createModuleContext(:com.google.android.gms@12673021@12.6.73 (040306-194189626):18)
                      at ryf.onTransact(:com.google.android.gms@12673021@12.6.73 (040306-194189626):12)
                      at android.os.Binder.transact(Binder.java:499)
                      at com.google.android.gms.internal.zzed.zza(Unknown Source)
                      at com.google.android.gms.dynamite.zzk.zza(Unknown Source)
                      at com.google.android.gms.dynamite.DynamiteModule.zzb(Unknown Source)
                      at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                      at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                      at com.google.android.gms.internal.ace.<init>(Unknown Source)
                      at com.google.android.gms.internal.ace.zzg(Unknown Source)
                      at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                      at com.google.firebase.storage.UploadTask.run(Unknown Source)
                      at com.google.firebase.storage.zzr.run(Unknown Source)
                      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                      at java.lang.Thread.run(Thread.java:776)
E/ChimeraModuleLdr: Failed to load code for module FileApk(/data/user_de/0/com.google.android.gms/app_chimera/m/00000039/DynamiteModulesC_GmsCore_prodmnc_xhdpi_release.apk)
                    ddp: Failed to load code for /data/user_de/0/com.google.android.gms/app_chimera/m/00000039/DynamiteModulesC_GmsCore_prodmnc_xhdpi_release.apk
                        at day.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):23)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):84)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):52)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):117)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):114)
                        at ryk.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):13)
                        at com.google.android.gms.chimera.container.DynamiteLoaderImpl.createModuleContext(:com.google.android.gms@12673021@12.6.73 (040306-194189626):18)
                        at ryf.onTransact(:com.google.android.gms@12673021@12.6.73 (040306-194189626):12)
                        at android.os.Binder.transact(Binder.java:499)
                        at com.google.android.gms.internal.zzed.zza(Unknown Source)
                        at com.google.android.gms.dynamite.zzk.zza(Unknown Source)
                        at com.google.android.gms.dynamite.DynamiteModule.zzb(Unknown Source)
                        at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                        at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                        at com.google.android.gms.internal.ace.<init>(Unknown Source)
                        at com.google.android.gms.internal.ace.zzg(Unknown Source)
                        at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                        at com.google.firebase.storage.UploadTask.run(Unknown Source)
                        at com.google.firebase.storage.zzr.run(Unknown Source)
                        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                        at java.lang.Thread.run(Thread.java:776)
W/ChimeraDebugLogger: Singleton logger instance not set.
E/DynamiteLoaderV2: Failed to create module context.
                    ddp: Failed to load code for /data/user_de/0/com.google.android.gms/app_chimera/m/00000039/DynamiteModulesC_GmsCore_prodmnc_xhdpi_release.apk
                        at day.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):23)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):84)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):52)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):117)
                        at ddn.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):114)
                        at ryk.a(:com.google.android.gms@12673021@12.6.73 (040306-194189626):13)
                        at com.google.android.gms.chimera.container.DynamiteLoaderImpl.createModuleContext(:com.google.android.gms@12673021@12.6.73 (040306-194189626):18)
                        at ryf.onTransact(:com.google.android.gms@12673021@12.6.73 (040306-194189626):12)
                        at android.os.Binder.transact(Binder.java:499)
                        at com.google.android.gms.internal.zzed.zza(Unknown Source)
                        at com.google.android.gms.dynamite.zzk.zza(Unknown Source)
                        at com.google.android.gms.dynamite.DynamiteModule.zzb(Unknown Source)
                        at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                        at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                        at com.google.android.gms.internal.ace.<init>(Unknown Source)
                        at com.google.android.gms.internal.ace.zzg(Unknown Source)
                        at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                        at com.google.firebase.storage.UploadTask.run(Unknown Source)
                        at com.google.firebase.storage.zzr.run(Unknown Source)
                        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                        at java.lang.Thread.run(Thread.java:776)
W/DynamiteModule: Failed to load remote module: Failed to load remote module.
E/NetworkRqFactoryProxy: NetworkRequestFactoryProxy failed with a RemoteException:
                         com.google.android.gms.dynamite.DynamiteModule$zzc: Remote load failed. No local fallback found.
                             at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                             at com.google.android.gms.internal.ace.<init>(Unknown Source)
                             at com.google.android.gms.internal.ace.zzg(Unknown Source)
                             at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                             at com.google.firebase.storage.UploadTask.run(Unknown Source)
                             at com.google.firebase.storage.zzr.run(Unknown Source)
                             at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                             at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                             at java.lang.Thread.run(Thread.java:776)
                          Caused by: com.google.android.gms.dynamite.DynamiteModule$zzc: Failed to load remote module.
                             at com.google.android.gms.dynamite.DynamiteModule.zzb(Unknown Source)
                             at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source)
                             at com.google.android.gms.dynamite.DynamiteModule.zza(Unknown Source) 
                             at com.google.android.gms.internal.ace.<init>(Unknown Source) 
                             at com.google.android.gms.internal.ace.zzg(Unknown Source) 
                             at com.google.firebase.storage.StorageReference.zzKO(Unknown Source) 
                             at com.google.firebase.storage.UploadTask.run(Unknown Source) 
                             at com.google.firebase.storage.zzr.run(Unknown Source) 
                             at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133) 
                             at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607) 
                             at java.lang.Thread.run(Thread.java:776) 
E/UploadTask: Unable to create a network request from metadata
              android.os.RemoteException
                  at com.google.android.gms.internal.ace.<init>(Unknown Source)
                  at com.google.android.gms.internal.ace.zzg(Unknown Source)
                  at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                  at com.google.firebase.storage.UploadTask.run(Unknown Source)
                  at com.google.firebase.storage.zzr.run(Unknown Source)
                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                  at java.lang.Thread.run(Thread.java:776)
E/StorageException: StorageException has occurred.
                    An unknown error occurred, please check the HTTP result code and inner exception for server response.
                     Code: -13000 HttpResult: 0
E/StorageException: null
                    android.os.RemoteException
                        at com.google.android.gms.internal.ace.<init>(Unknown Source)
                        at com.google.android.gms.internal.ace.zzg(Unknown Source)
                        at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                        at com.google.firebase.storage.UploadTask.run(Unknown Source)
                        at com.google.firebase.storage.zzr.run(Unknown Source)
                        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                        at java.lang.Thread.run(Thread.java:776)
                    StorageException has occurred.
                    An unknown error occurred, please check the HTTP result code and inner exception for server response.
                     Code: -13000 HttpResult: 0
                    null
                    android.os.RemoteException
                        at com.google.android.gms.internal.ace.<init>(Unknown Source)
                        at com.google.android.gms.internal.ace.zzg(Unknown Source)
                        at com.google.firebase.storage.StorageReference.zzKO(Unknown Source)
                        at com.google.firebase.storage.UploadTask.run(Unknown Source)
                        at com.google.firebase.storage.zzr.run(Unknown Source)
                        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
                        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
                        at java.lang.Thread.run(Thread.java:776)
E/HW-JPEG-DEC: [HME_JPEG_DEC_Delete](3321): HME_JPEG_DEC_Delete: decoder_ctx=null
E/HW-JPEG-DEC: [HME_JPEG_DEC_Delete](3321): HME_JPEG_DEC_Delete: decoder_ctx=null
I/HwPointEventFilter: do not support AFT because of no config

build.gradle:

    apply plugin: 'com.android.application'

android {
    compileSdkVersion 26
    defaultConfig {
        applicationId 'com.example.sarin.guff'
        minSdkVersion 18
        targetSdkVersion 26
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        multiDexEnabled true
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    productFlavors {
    }
}

dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    implementation 'com.android.support:appcompat-v7:26.1.0'
    implementation 'com.android.support:support-v4:26.1.0'
    implementation 'com.google.firebase:firebase-database:11.0.4'
    implementation 'com.google.firebase:firebase-storage:11.0.4'
    implementation 'com.google.firebase:firebase-messaging:11.0.4'
    implementation 'com.android.support:design:26.1.0'
    implementation 'com.android.support.constraint:constraint-layout:1.0.2'
    implementation 'com.google.firebase:firebase-auth:11.0.4'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.1'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
    implementation 'com.firebase:firebase-client-android:2.5.2+'
    implementation 'com.android.support:mediarouter-v7:26.1.0'
    implementation 'de.hdodenhof:circleimageview:2.2.0'
    implementation 'com.theartofdev.edmodo:android-image-cropper:2.5.+'
    implementation 'com.squareup.picasso:picasso:2.5.2'
    implementation 'com.github.dimorinny:floating-text-button:0.0.4'
    implementation 'com.firebaseui:firebase-ui-database:2.3.0'
    implementation 'id.zelory:compressor:2.0.0'
    implementation 'com.willowtreeapps.spruce:spruce-android:1.0.1'
    implementation 'com.squareup.okhttp:okhttp:2.5.0'
    implementation 'com.android.support:recyclerview-v7:26.1.0'
    implementation 'com.android.support:cardview-v7:26.1.0'
    implementation 'com.github.bumptech.glide:glide:4.0.0'
    annotationProcessor 'com.github.bumptech.glide:compiler:4.0.0'
    implementation 'hani.momanii.supernova_emoji_library:supernova-emoji-library:0.0.2'
    implementation 'com.tbruyelle.rxpermissions2:rxpermissions:0.9.1@aar'
    implementation 'com.zhihu.android:matisse:0.4.3'
    implementation 'com.github.mancj:MaterialSearchBar:0.7.6'
    implementation 'com.getbase:floatingactionbutton:1.10.1'
    implementation 'com.miguelcatalan:materialsearchview:1.4.0'
    implementation 'com.hanks:passcodeview:0.1.2'
    implementation "com.google.android.gms:play-services-maps:11.0.4"
    implementation 'org.apache.commons:commons-lang3:3.6'
    implementation 'com.google.android.gms:play-services-places:11.0.4'
    implementation 'com.android.support:multidex:1.0.3'
    implementation 'com.flaviofaria:kenburnsview:1.0.7'
}
apply plugin: 'com.google.gms.google-services'

Gradle сборки проекта:

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {

    repositories {
        google()
        jcenter()
        mavenCentral()

    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.1.2'


        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
        classpath 'com.google.gms:google-services:3.1.1'
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url "https://jitpack.io" }
        maven { url "https://dl.bintray.com/hani-momanii/maven"}
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

ПРАВИЛО ХРАНЕНИЯ ФАЙНОВ:

service firebase.storage {
  match /b/{bucket}/o {
    match /{allPaths=**} {
      allow read, write: if request.auth != null;
    }
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...