尝试从 firebase 获取图像,以便用户可以设置个人资料图像,但它是空白的

Trying to get image from firebase so that user can set profile image but its blank

我正在尝试让用户单击图片项并从他们的条样中选择图片。然后这张图片应该被推送到 firebase 并自动添加到图像视图中,但是在我关闭应用程序后它显示为空白。我尝试了多种方法,但似乎无法正常工作。这是我实现所有内容的地方:

public class MainActivity extends AppCompatActivity implements NavigationView.OnNavigationItemSelectedListener {
    ImageView imageView;
    public static final int IMAGE_CODE = 1;
    Uri imageUri;
    private StorageReference storageReference;
    private DatabaseReference databaseReference;
    FirebaseUser user;
    String userid;

   protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        imageView = (ImageView) headerView.findViewById(R.id.profilepic);
        user = FirebaseAuth.getInstance().getCurrentUser();
        userid = user.getUid();
        storageReference = FirebaseStorage.getInstance().getReference("Images");
        databaseReference = FirebaseDatabase.getInstance().getReference("uploads").child(userid);

        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                openimage();
            }
        });
        profileImage(); 
   }

   private void profileImage(){
   databaseReference.addListenerForSingleValueEvent(new ValueEventListener() {
          @Override
          public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
              if(dataSnapshot.exists()) {
                  Upload upload = dataSnapshot.getValue(Upload.class);
                  Glide.with(getApplicationContext()).load(upload.getUplaodUri()).into(imageView);
              }
          }

          @Override
          public void onCancelled(@NonNull DatabaseError databaseError) {
              Toast.makeText(MainActivity.this, databaseError.getMessage(), Toast.LENGTH_SHORT).show();

          }
      });
   }

   private void openimage() {
        Intent galleryIntent = new Intent(Intent.ACTION_PICK,
                android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);

        startActivityForResult(galleryIntent, IMAGE_CODE);
    }


    @TargetApi(Build.VERSION_CODES.M)
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode == ACTION_MANAGE_OVERLAY_PERMISSION_REQUEST_CODE) {
            if (!Settings.canDrawOverlays(this)) {
                // You don't have permission
                checkPermission1();
            } else {
                // Do as per your logic
            }

        }
        if (requestCode == IMAGE_CODE && resultCode == RESULT_OK && null != data && data.getData() != null) {
            imageUri = data.getData();
            Glide.with(this).load(imageUri).into(imageView);

            fileUploader();

        }
    }
    private String getFileExtension(Uri uri){
        ContentResolver cr = getContentResolver();
        MimeTypeMap mimeTypeMap = MimeTypeMap.getSingleton();
        return mimeTypeMap.getExtensionFromMimeType(cr.getType(uri));
    }
    private void fileUploader(){
        if(imageUri != null){
            StorageReference reference = storageReference.child(userid + ".jpeg");

            reference.putFile(imageUri).addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() {
                @Override
                public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) {

                    reference.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
                        @Override
                        public void onSuccess(Uri uri) {
                            Upload upload = new Upload(uri.toString());
                            databaseReference.setValue(upload).addOnSuccessListener(new OnSuccessListener<Void>() {
            @Override
            public void onSuccess(Void aVoid) {
                profileImage();
            }
        });
                        }
                    });



                }
            }).addOnFailureListener(new OnFailureListener() {
                @Override
                public void onFailure(@NonNull Exception e) {
                    Toast.makeText(MainActivity.this, e.getMessage(), Toast.LENGTH_SHORT).show();
;;
                }
            });

        }else{
            Toast.makeText(MainActivity.this, "Error", Toast.LENGTH_SHORT).show();

        }

    }
}

Database Structure

编辑:

2020-05-03 15:55:51.232 25230-25407/com.example.carcrashdetection E/StorageException: StorageException has occurred.
    Object does not exist at location.
     Code: -13010 HttpResult: 404
2020-05-03 15:55:51.235 25230-25407/com.example.carcrashdetection E/StorageException: {  "error": {    "code": 404,    "message": "Not Found.  Could not get object",    "status": "GET_OBJECT"  }}
    java.io.IOException: {  "error": {    "code": 404,    "message": "Not Found.  Could not get object",    "status": "GET_OBJECT"  }}
        at com.google.firebase.storage.network.NetworkRequest.parseResponse(com.google.firebase:firebase-storage@@19.1.1:433)
        at com.google.firebase.storage.network.NetworkRequest.parseErrorResponse(com.google.firebase:firebase-storage@@19.1.1:450)
        at com.google.firebase.storage.network.NetworkRequest.processResponseStream(com.google.firebase:firebase-storage@@19.1.1:441)
        at com.google.firebase.storage.network.NetworkRequest.performRequest(com.google.firebase:firebase-storage@@19.1.1:272)
        at com.google.firebase.storage.network.NetworkRequest.performRequest(com.google.firebase:firebase-storage@@19.1.1:286)
        at com.google.firebase.storage.internal.ExponentialBackoffSender.sendWithExponentialBackoff(com.google.firebase:firebase-storage@@19.1.1:70)
        at com.google.firebase.storage.internal.ExponentialBackoffSender.sendWithExponentialBackoff(com.google.firebase:firebase-storage@@19.1.1:62)
        at com.google.firebase.storage.GetDownloadUrlTask.run(com.google.firebase:firebase-storage@@19.1.1:76)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
        at java.lang.Thread.run(Thread.java:919)

此外,图片位于导航抽屉中,每个用户都应该是唯一的。谁能告诉我哪里出错了?

你可以这样做:

reference.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
   @Override
    public void onSuccess(Uri uri) {
           Upload upload = new Upload(uri.toString());
           String uploadId = databaseReference.child(userid).push().getKey();
           databaseReference.child(uploadId).setValue(upload);
    }
});

Firebase 存储docs

这一行有问题:

Glide.with(getApplicationContext()).load(upload).into(imageView);

上传是一个对象。你应该使用 upload.getUploadUri()

if(dataSnapshot.exists()) {
   for (DataSnapshot ds : dataSnapshot.getChildren()){
        Upload upload = ds.getValue(Upload.class);
        Glide.with(getApplicationContext()).load(upload.getUplaodUri()).into(imageView);    
   }

}

您总是以这种方式查看上次上传的图片。如果用户有图片,则不需要使用 uploadId。

个人资料图片:

    Upload upload = new Upload(uri.toString());
    databaseReference.setValue(upload);

和:

 if(dataSnapshot.exists()) {
       Upload upload = dataSnapshot.getValue(Upload.class);
       Glide.with(getApplicationContext()).load(upload.getUplaodUri()).into(imageView); 
 }

对你更有用。