Serve images with Cloudfront + S3
data:image/s3,"s3://crabby-images/541ae/541ae3a8e9f5fc3c7002cc913520d70a5db69652" alt=""
To Do :-
- Create a S3 Bucket.
- Create Cloudfront Distributions.
- Check the bucket policy of S3.
- Operation Check.
Create a S3 Bucket :-
- Open “Services> S3”. Then, create an S3 bucket with all recommended settings.
- Block all public access as shown in below.
data:image/s3,"s3://crabby-images/05478/05478541dfc24152dbf6f05f3d110ead393aa0f5" alt=""
Create Cloudfront Distributions :-
Open “Services > Cloudfront”. Then, click create distribution.
Follow the below instructions.
- Origin Domain Name: [Your S3 buckets] Select the S3 bucket made in
- Restrict Bucket Access: Yes If you set this to Yes, you can restrict access to S3 only from Cloudfront.
- Origin Access Identity: If you are the first to create Cloudfront Distribution, select “Create a New Identity”. If you already created an “origin access identity”, you can select it in “Use an Existing Identity”. One “origin access identity” is usually sufficient.
- Grant Read Permissions on Bucket: Yes, Update Bucket Policy If this is set to “Yes”, a policy setting will be automatically added to S3’s Bucket Policy. See # 3 for details.
It will look like this in the distribution settings.
data:image/s3,"s3://crabby-images/0ac5f/0ac5ff987c6bed32b90aad054734bd9636805b2e" alt=""
- Then, leave the remaining fields as default (or) recommended settings in the distribution fields.
- Then, create distribution.
data:image/s3,"s3://crabby-images/4c299/4c299adcbea27dad44d1ebfba055c25a62d4b8c6" alt=""
Check the bucket policy of S3 :-
You can check the bucket policy in “Services> S3 > [Your bucket] > Permissions > Bucket Policy”.
data:image/s3,"s3://crabby-images/fae15/fae153e50f8f5d3a93eb0b13c829076e777dd18e" alt=""
The bucket will automatically get updated in the bucket policy.
Upload an image to S3 for testing. Make all the values default (recommended values).
data:image/s3,"s3://crabby-images/6f2e2/6f2e2bec339618ee0bad2fdee27b8ebc07190656" alt=""
Then First, open the S3 “Object URL” and check that it becomes “Access Denied”.
data:image/s3,"s3://crabby-images/753ac/753ac7f0f3c7029b7530850eaa93fd4258a5f230" alt=""
Next, open Cloud Front’s “Domain Name” and check that the image is displayed.
Eg: – cloudfrontsdomainname/imagenameins3
data:image/s3,"s3://crabby-images/60383/603836cdf4fa94b05078d7b8492bf90573336e0e" alt=""