- Newest
- Most votes
- Most comments
I would follow these debugging steps
Verify CloudFront Distribution Configuration:
-
Ensure that your CloudFront distribution is configured to serve HTTPS traffic. Check the "Viewer Protocol Policy" under the "Behaviors" tab of your CloudFront distribution. It should be set to "Redirect HTTP to HTTPS" or "HTTPS Only".
-
Confirm that your CloudFront distribution has a valid SSL/TLS certificate associated with it. This can be a certificate from ACM (AWS Certificate Manager) or a custom SSL certificate that you've uploaded.
-
Check the Origin Access Identity (OAI):
-
Verify that your S3 bucket is using an Origin Access Identity (OAI) and that the bucket policy allows this OAI to access the files. The OAI should have permissions to access the objects in your S3 bucket.
-
The bucket policy should specifically grant GetObject permission to the OAI used by your CloudFront distribution.
-
Inspect S3 Bucket Permissions:
-
Double-check the S3 bucket and object permissions to ensure there are no explicit "Deny" statements that might be interfering with access via CloudFront, especially over HTTPS.
-
Ensure that there are no bucket policies or IAM policies that specifically restrict access based on the protocol used (HTTP vs HTTPS).
-
Review CloudFront Custom Error Pages:
-
In the CloudFront distribution settings, check if there are any custom error pages configured that might be handling HTTPS requests differently from HTTP requests.
-
Test with Alternate Methods:
-
Use tools like curl to test accessing your CloudFront URLs directly from the command line, both with HTTP and HTTPS, to see if the issue can be replicated outside of a browser. This can help isolate whether the issue is browser-specific or a broader configuration issue.
-
Analyze CloudFront and S3 Logs:
-
While you've mentioned that logs are sparse, try to correlate the timestamp of an "Access Denied" error in CloudFront logs with the corresponding S3 access logs. This might give clues, especially regarding the request headers or the request protocol.
-
Check DNS Configuration:
-
Ensure that your DNS records are correctly pointing to your CloudFront distribution and that there are no issues with DNS propagation.
-
Additional Considerations
-
HTTPS Enforcement by Browsers: If browsers are upgrading HTTP URLs to HTTPS and causing issues, ensuring that your CloudFront distribution fully supports HTTPS is critical. This includes having a valid SSL certificate and correctly configured DNS records.
-
Mixed Content: If your page is served over HTTPS but contains mixed content (some resources are loaded over HTTP), browsers may block those resources. Ensure all resources are loaded over HTTPS.
Relevant content
- asked 7 years ago
- AWS OFFICIALUpdated 4 months ago
- AWS OFFICIALUpdated a year ago
- AWS OFFICIALUpdated 2 months ago
- AWS OFFICIALUpdated 8 months ago