By default, all S3 buckets and objects are private and only the account that owns the objects has permissions to access them. You can however generate pre-signed url for the S3 objects and share it with anyone. Generating pre-signed url requires valid security credentials.
In this example, I have an object welcome.html in my S3 bucket named aws-presigned.
data:image/s3,"s3://crabby-images/64628/64628fd4d949ed2109c51e80c1be2a6c1b2b46d7" alt=""
S3 object welcome.html is currently not accessible from the browser.
data:image/s3,"s3://crabby-images/fec69/fec69b7a9bd8e7c0a14fa96cf50987d73708cd0c" alt=""
To generate pre-signed url for welcome.html, I used the command:
aws s3 presign –expires-in 30 s3://aws-presigned/welcome.html where 30 is the expiration time in seconds and aws-presigned/welcome.html is the object key.
The EC2 Instance that I used to generate pre-signed URL has access to S3 through an IAM role. Thus the credentials used to generate this pre-signed url are from the IAM role.
data:image/s3,"s3://crabby-images/1ac9d/1ac9d78bbb52fe5035afd57a525ad798f6735722" alt=""
Copy the pre-signed url generated from above command into the browser and voila!! The welcome.html file is now accessible. You can share this pre-signed url with anyone that requires access to the object.
data:image/s3,"s3://crabby-images/551f0/551f049f3a80daf644bdb0a0e9ee044e9e632a6c" alt=""
The url is valid only for the expiration duration specified in the request. After the duration has expired, you will see the below output from the pre-signed url.
data:image/s3,"s3://crabby-images/061b8/061b81a22cff824ad968299fb9ea0ea94ea45716" alt=""
Thus using pre-signed url, you can securely share S3 objects with users that do not have AWS account without making the bucket or objects public.