When I created the Flutter Android App, I thought of cross-platform as one of my reasons for trying out Flutter.
I read that Flutter Web is still in early support, however, it will be good to try it out. I want to see how to host it on Amazon Web Services itself. If I can host my app on AWS, it will turn my project into a fully serverless and cloud-based concept.
Adding Web support to my Flutter App
To add web support, first I ran these commands in my flutter app directory.
I followed this guide: https://flutter.dev/docs/get-started/web
Run the commands:
$ flutter channel beta
$ flutter upgrade
$ flutter config --enable-web
$ flutter devices
$ flutter run -d web-server --release
Hosting on AWS S3
In the end, I chose AWS S3 as a suitable service because I realised that I can generate the Flutter app as a static webpage.
I followed this guide closely to set up the S3 bucket, permissions and properties:
Go to S3 console and create a new bucket
data:image/s3,"s3://crabby-images/26d25/26d257945594fff9eeb7ac7f639df31bf47d4b28" alt=""
Under properties, I enabled static web hosting. I went with all the default settings
data:image/s3,"s3://crabby-images/fc7da/fc7da7fd66c2c9a0c3c5aa072549cd1add47f777" alt=""
Here, we can see that it is enabled afterwards
data:image/s3,"s3://crabby-images/f7ec9/f7ec980388d82cd821a11a25f0482fe6a0d40207" alt=""
We need to allow public access, so I went to permissions to edit the bucket policy.
data:image/s3,"s3://crabby-images/7bfe2/7bfe29a2abaf357f2c276b9a99f523e342528445" alt=""
I modified to have this bucket policy for my use-case:
{
"Id": "PolicyForPublicWebsiteContent",
"Version": "2012-10-17",
"Statement": [
{
"Sid": "PublicReadGetObject",
"Action": [
"s3:GetObject"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::cypress-psoc/*",
"Principal": "*"
}
]
}
I then uploaded all the files from the build directory: ./flutter_fimble/build/web/
And as simple as that, my app is now hosted online live! It was way easier than I thought!
data:image/s3,"s3://crabby-images/936a0/936a0263ae39fa1cf2e23e9b8f48bf2a3136d18e" alt=""
data:image/s3,"s3://crabby-images/d5229/d52291f10248e4eae8c4cd012438ef4bfa5761c6" alt=""
data:image/s3,"s3://crabby-images/f6ade/f6ade03d694d6650969f5cef423bb2cc5c5868d6" alt=""
Discussions
Become a Hackaday.io Member
Create an account to leave a comment. Already have an account? Log In.