How to upload Image to Firebase Storage in Android
Hello world, today we are going to learn how we can upload an image to the firebase storage from our android application. We will see how we can show the progress of uploading an image to the user. Firebase storage gives use utility to upload the file and get the URL of that uploaded file so that we can access our file through the link. Let's see the final result we are going to learn.
Before staring the code we need to enable firebase storage in our Firebase project. Open your Firebase console and select the project and click on storage then follow the on-screen instructions.
After creating the storage we need to change our storage rule so that we can access the storage with the authentication.
Open your rules and change the if condition and replace != to ==.
After make changes hit the publish button and we are ready to go.
In your android project add these dependencies to work with firebase storage.
implementation 'com.google.firebase:firebase-storage:19.1.1' | |
implementation 'com.github.dhaval2404:imagepicker:1.7.4' |
Add This in the project level build.gradle.
allprojects { | |
repositories { | |
... | |
... | |
maven { url "https://jitpack.io" } | |
} | |
} |
the first dependency is for firebase storage and the last dependency is for pick images from gallery or camera.
After adding the dependencies. Let's see what tasks we need to perform to upload an image to the firebase.
- Pick an image from the gallery or camera.
- Display picked image into ImageView.
- Upload image on Click of the button.
- Display progress bar while uploading.
- After Uploading, get the uploaded image link.
Pick an image from the Gallery or Camera
The first step is to pick the image from the gallery or camera for that we will going to use this library https://github.com/Dhaval2404/ImagePicker. Let's create our layout so that we can button and imageview. Open your activity_main.xml file and add this code.
<?xml version="1.0" encoding="utf-8"?> | |
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | |
xmlns:app="http://schemas.android.com/apk/res-auto" | |
xmlns:tools="http://schemas.android.com/tools" | |
android:layout_width="match_parent" | |
android:layout_height="match_parent" | |
tools:context=".MainActivity" | |
android:padding="15sp" | |
> | |
<TextView | |
android:layout_width="wrap_content" | |
android:layout_height="wrap_content" | |
android:text="Click to choose image" | |
app:layout_constraintBottom_toBottomOf="@id/imageView" | |
app:layout_constraintLeft_toLeftOf="@id/imageView" | |
app:layout_constraintRight_toRightOf="@id/imageView" | |
app:layout_constraintTop_toTopOf="@id/imageView" /> | |
<ImageView | |
android:id="@+id/imageView" | |
android:layout_width="200sp" | |
android:layout_height="200sp" | |
android:layout_marginTop="20sp" | |
android:background="?selectableItemBackground" | |
android:clickable="true" | |
android:focusable="true" | |
android:scaleType="centerCrop" | |
app:layout_constraintLeft_toLeftOf="parent" | |
app:layout_constraintRight_toRightOf="parent" | |
app:layout_constraintTop_toTopOf="parent" /> | |
<ProgressBar | |
android:id="@+id/progressBar" | |
style="@style/Widget.AppCompat.ProgressBar.Horizontal" | |
android:layout_width="match_parent" | |
android:layout_height="wrap_content" | |
android:layout_marginTop="10sp" | |
app:layout_constraintTop_toBottomOf="@id/imageView" /> | |
<TextView | |
android:id="@+id/progressTextView" | |
android:layout_width="wrap_content" | |
android:layout_height="wrap_content" | |
app:layout_constraintRight_toRightOf="@id/progressBar" | |
app:layout_constraintTop_toBottomOf="@id/progressBar" | |
/> | |
<Button | |
android:id="@+id/uploadButton" | |
android:layout_width="wrap_content" | |
android:layout_height="wrap_content" | |
android:backgroundTint="#2D8AFA" | |
android:text="Upload" | |
android:textAllCaps="false" | |
android:textColor="@android:color/white" | |
app:layout_constraintLeft_toLeftOf="parent" | |
app:layout_constraintRight_toRightOf="parent" | |
app:layout_constraintTop_toBottomOf="@id/progressBar" /> | |
<TextView | |
android:id="@+id/imageLinkTextView" | |
android:layout_width="match_parent" | |
android:layout_height="wrap_content" | |
android:layout_marginTop="50sp" | |
android:textAppearance="@style/TextAppearance.AppCompat.Title" | |
android:textIsSelectable="true" | |
app:layout_constraintLeft_toLeftOf="parent" | |
app:layout_constraintRight_toRightOf="parent" | |
app:layout_constraintTop_toBottomOf="@id/uploadButton" /> | |
</androidx.constraintlayout.widget.ConstraintLayout> |
In the layout, we have an imageview to show the image when we choose from the gallery. A progress bar and a textview to show the progress of uploading an image and an upload button to start uploading. A simple layout.
We will pick an image on the click of imageview we need to add click listener and write code for start activity to pick an image. See the below code.
imageView = findViewById(R.id.imageView); | |
imageView.setOnClickListener(new View.OnClickListener() { | |
@Override | |
public void onClick(View v) { | |
ImagePicker | |
.Companion | |
.with(MainActivity.this) | |
.start(); | |
} | |
}); |
In the above code, we are starting the image picker and to get the image URI in the onActivityResult method. Let's override this method in our class.
@Override | |
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { | |
super.onActivityResult(requestCode, resultCode, data); | |
if(resultCode ==RESULT_OK){ | |
if (data != null) { | |
fileUri = data.getData(); | |
imageView.setImageURI(fileUri); | |
} | |
} | |
} |
Display picked image into ImageView
After getting the image URI we will set the URI to imageview so that the user can know which image he chose.
Note: if you are getting FileNotFound Exception then add android:requestLegacyExternalStorage="true" to the application tag in the manifest.xml file.
We are storing the image URI in the variable.
See also: Android Bottom Sheet
Upload image on Click of the button
Now we will upload the image on the click of the button. Let's implement the on click function on the button.
Button uploadButton = findViewById(R.id.uploadButton); | |
uploadButton.setOnClickListener(new View.OnClickListener() { | |
@Override | |
public void onClick(View v) { | |
StorageReference storageRef = FirebaseStorage.getInstance().getReference(); | |
StorageReference uploadImageRef = storageRef.child("images/"+fileUri.getLastPathSegment()); | |
UploadTask uploadTask = uploadImageRef.putFile(fileUri); | |
uploadTask.addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() { | |
@Override | |
public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) { | |
} | |
}).addOnFailureListener(new OnFailureListener() { | |
@Override | |
public void onFailure(@NonNull Exception e) { | |
Toast.makeText(MainActivity.this, "Failed to Upload Image", Toast.LENGTH_SHORT).show(); | |
} | |
}); | |
} | |
}); |
First, we are getting the storage reference then we are uploading the image in the images folder and then concatenate the original image name with the file format using the URI method getLastPathSegment. This method returns the file name.
After that, we are uploading the image using the uploadImageRef and calling its method putFile and pass our file Uri.
Then we will add a successful listener and failure listener. When your file successfully uploads then addOnSuccessListener called and when there will be any error then addOnFailureListener called.
Now see how to show progress bar while uploading.
Display progress bar while uploading
To display progress while uploading the file or image. We will add addOnProgressListener to the UploadTask. Check the below code.
uploadTask.addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() { | |
@Override | |
public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) { | |
... | |
} | |
}).addOnFailureListener(new OnFailureListener() { | |
@Override | |
public void onFailure(@NonNull Exception e) { | |
... | |
} | |
}).addOnProgressListener(new OnProgressListener<UploadTask.TaskSnapshot>() { | |
@Override | |
public void onProgress(@NonNull UploadTask.TaskSnapshot taskSnapshot) { | |
double progress = (100.0 * taskSnapshot.getBytesTransferred()) / taskSnapshot.getTotalByteCount(); | |
progressBar.setProgress((int) progress); | |
String progressString = ((int) progress) + "% done"; | |
progressTextView.setText(progressString); | |
} | |
}); |
In the addOnProgressListener method, we are calculating the progress by multiply 100 with data uploaded and divided by the total size of the file or image.
Then we set the progress of the progress bar and also set the text of textview to show the progress. This way we easily calculate the progress and set to the progress bar.
Sometimes we have the case when we use putStrem and pass InputeStrem object instead of putFile. In this case, if we call the getTotalByteCount method we get -1 in return. To get the file size of InputStream e can use available method to get the current data size. Note that call the available method right after the InputStream method.
Now the only thing is left is to get the link of the file which we just uploaded.
After Uploading, get the uploaded image link
To get the download link of the image or file we need to add code in the success listener of the UploadTask.
uploadTask.addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() { | |
@Override | |
public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) { | |
taskSnapshot.getStorage().getDownloadUrl().addOnCompleteListener(new OnCompleteListener<Uri>() { | |
@Override | |
public void onComplete(@NonNull Task<Uri> task) { | |
uploadedImageUrl = task.getResult().toString(); | |
TextView imageLinkTextView = findViewById(R.id.imageLinkTextView); | |
imageLinkTextView.setText(uploadedImageUrl); | |
} | |
}); | |
} | |
}) |
This way we can get our download link of the file which we have just uploaded.
You can save this URL to the database for later use maybe.
Now you can run your project and your app will run smoothly.
If you learned something new then do share this article with your friends and batchmates and don't forget to subscribe to our newsletter if you haven't joined already for the latest updates.
Thanks for reading have a nice day.
Subscribe to our Newsletter
By subscribing to our newsletter you're agreeing with our T&C.