Create public buckets on R2
Public Bucket is a feature that allows users to expose the contents of their R2 buckets directly to the Internet. By default, buckets are never publicly accessible and will always require explicit user permission to enable.
Public buckets can be set up in either one of two ways:
- Expose your bucket as a custom domain under your control.
- Expose your bucket as a Cloudflare-managed subdomain under https://r2.dev.
To configure WAF custom rules, caching, access controls, or bot management for your bucket, you must do so through a custom domain.
Using a custom domain does not require enabling r2.dev.
 Custom domains
 Caching
Domain access through a custom domain allows you to use Cloudflare Cache to accelerate access to your R2 bucket.
 Access control
To restrict access to your custom domain’s bucket, use Cloudflare’s existing security products.
- Cloudflare Zero Trust Access: Protects buckets that should only be accessible by your teammates.
- Cloudflare WAF Token Authentication: Restricts access to documents, files, and media to selected users by providing them with an access token.
 Connect a bucket to a custom domain
- Go to R2 and select your bucket.
- On the bucket page, select Settings.
- Under Public access > Custom Domains, select Connect Domain.
- Enter the domain name you want to connect to and select Continue.
- Review the new record that will be added to the DNS table and select Connect Domain.
Your domain is now connected. The status takes a few minutes to change from Initializing to Active, and you may need to refresh to review the status update. If the status has not changed, select the … next to your bucket and select Retry connection.
To view the added DNS record, select … next to the connected domain and select Manage DNS.
 Restrictions
There are a few restrictions when using custom domains to access R2 buckets.
- The domain being used must belong to the same account as the R2 bucket.
- Use of a domain with CNAME flattening enabled is not supported. You will need to disable CNAME flattening before enabling domain access.
- Object access is only available via HTTPS; plaintxt HTTP is not supported.
 Disable domain access
Disabling a domain will turn off public access to your bucket through that domain. Access through other domains or the managed r2.dev subdomain are unaffected.
The specified domain will also remain connected to R2 until you remove it or delete the bucket.
To disable a domain:
- In R2, select the bucket you want to modify.
- On the bucket page, Select Settings.
- Under Public access > Custom Domains, select Connect Domain.
- Next to the domain you want to disable, select … and Disable domain.
- The badge under Access to Bucket will update to Not allowed.
 Remove domain
Removing a domain will remove custom domain configuration that you have set up on the dashboard. Your bucket will still be publicly accessible.
To remove a domain:
- In R2, select the bucket you want to modify.
- On the bucket page, select Settings.
- Under Public access > Custom Domains, select Connect Domain.
- Next to the domain you want to disable, select … and Remove domain.
- Select ‘Remove domain’ in the confirmation window. The CNAME record pointing to the domain will also be removed as part of this step. You can always add the domain again.
The domain is no longer connected to your bucket and will no longer appear in the connected domains list.
 Enable managed public access
When you enable managed public access for your bucket, the content of your bucket is available to the Internet through a Cloudflare-managed r2.dev subdomain.
To enable access through r2.dev for your buckets:
- In R2, select the bucket you want to modify.
- On the bucket page, select Settings.
- In Settings, go to Public Access.
- Under R2.dev subdomain, select Allow Access.
- In Allow Public Access?, confirm your choice by typing ‘allow’ to confirm and select Allow.
- You can now access the bucket and its objects using the Public Bucket URL.
You can review if your bucket is publicly accessible by going to your bucket and checking that Public URL Access states Allowed.
 Disable managed public access
Your bucket will not be exposed to the Internet as an r2.dev subdomain after you disable public access. If you have connected other domains, the bucket will remain accessible on those domains.
To disable public access for your bucket:
- In R2, select the bucket you want to modify.
- On the bucket page, select Settings.
- Under Bucket Details > R2.dev subdomain, select Disallow Access.
- In Disallow Public Access?, type ‘disallow’ to confirm and select Disallow.
Your bucket and its objects can no longer be accessed using the Public Bucket URL.