Introduction
Here is how to host your Flutter web app with Firebase Hosting. This article guides you through all the steps needed. This service is free of charge!
Flutter apps are available for various platforms like Android, iOS, desktop systems, and also the web. With Firebase Hosting, there is an easy tool to deploy your Flutter web app and access it in a browser. This is a simple way to distribute apps to testers or automate the release process of new versions. Here is how to host your Flutter web app with Firebase Hosting.
Flutter ❤️ Firebase
data:image/s3,"s3://crabby-images/86508/865086ab5e93737a3250217222c35377b293b0ef" alt=""
Get started with Firebase and learn how to use it in your Flutter apps. My detailed ebook delivers you everything you need to know! Flutter and Firebase are a perfect match!
💡 Tip
Do you already have a Firebase project? If not, follow my setup article below with all steps in detail!
Open any command line tool (PowerShell, cmd, bash, Visual Studio terminal, …) and navigate to your Flutter project. Then, execute the command firebase init hosting
.
data:image/s3,"s3://crabby-images/25fb3/25fb300dd3c5b980850713b3c344de9db3a3cb2e" alt="Screenshot of the initialization of Firebase Hosting by author"
You will be asked several questions. Answer them like me in the image above to get a feeling of the workflow. Set your public directory to build/web
because this is the location where the Flutter framework will put the files for the web app. This will then be deployed to Firebase Hosting.
data:image/s3,"s3://crabby-images/be72f/be72fbb41c6f35c6cf21c16c7a4b89755d75eb07" alt="Screenshot of the build process of a Flutter web app by author"
Run the command flutter build web
to create the web app.
data:image/s3,"s3://crabby-images/57f6b/57f6b680289ca887bba70c5cf49251129726daf1" alt="Screenshot of the deployment of the Flutter web app to Firebase Hosting by author"
Afterward, use the command firebase deploy --only hosting
to publish the web app to Firebase Hosting.
data:image/s3,"s3://crabby-images/91b35/91b35439dd07184470dc700494799f4b5e6a167d" alt="Screenshot of the deployed Flutter web app with Firebase Hosting by author"
The Hosting URL
of the command-line output points to the location where the web app is running. Open it in a browser and verify that everything works as intended. If you use the provided demo application, you should see something like the image above.
To manage your releases, you can use the Firebase Hosting dashboard.
In the Build menu, go to Hosting.
data:image/s3,"s3://crabby-images/e54b1/e54b179258d26f5b658ad039dd4e67cc57860faf" alt="Screenshot of the Hosting menu in Firebase by author"
You can see the deployed version in the release overview.
data:image/s3,"s3://crabby-images/5d17b/5d17b0401e81e80f2033f516874afd9ddc6017b0" alt="Screenshot of release overview in Firebase Console by author"
That’s it. Your web app is published and can be managed with Firebase Hosting! ?
How can I deploy to a preview channel?
Follow the steps describe before but when deploying, use the command firebase hosting:channel:deploy CHANNEL_NAME
to push your deployment to Firebase. A new channel will appear in the Hosting dashboard. You can customize its storage settings and expiration time by clicking on the date button. By default, the channel will be deleted after 7 days and store 10 releases at most.
data:image/s3,"s3://crabby-images/80e85/80e85898ab74c1d515fb3eda8fe337c613b7b0fa" alt="Screenshot of a preview channel in Firebase Hosting by author"
How can I delete a previous release to free up storage space?
In Firebase Console, go to Hosting and look for the desired deployment in your release history. Click the three dots on the right and select Delete. This will schedule a deletion of the deployed contents within 24 hours. However, the table entry will remain.
You can only delete previous releases but not the active one.
How can I change Firebase Hosting settings?
You can either rerun the firebase init hosting
command or edit the firebase.json
file in your repository manually. In any case, you have to follow up with the command firebase deploy --only hosting
to publish the changes.
Conclusion
In this article, we learned how to host your Flutter web app with Firebase Hosting. You can find an example app on my GitHub page. Deploy it to your Firebase project to test.
Related articles
data:image/s3,"s3://crabby-images/33227/33227b461ef785eff057aeafa42dad6e65e386c1" alt="Firebase category image"
data:image/s3,"s3://crabby-images/33227/33227b461ef785eff057aeafa42dad6e65e386c1" alt="Firebase category image"