请原谅我,如果之前有人询问过,有很多资源可以触及,但似乎没有什么适合我的特定(https)用例。
我正在尝试将https://www.example.com重定向到https://example.com。同样,这应该适用于http://www.example.com到https://example.com。
我已经设置了一个带有s3存储桶源的云端分发,将http重定向到https,添加了cname example.com并添加了我的域证书(适用于www子域以及裸域)。
我还设置了一个单独的发行版,其中包含www.example.com的cname,添加了证书并将原点设置为一个单独的s3存储桶,在(静态网站托管)中将所有请求重定向到https://example.com。
重定向工作正如http://example.com到https://example.com所预期的那样,但是http:s / x://www.example.com到https://example.com没有。
在路由53中,我将根域别名为第一个云端分布,而www别名为第二个。
在AWS上托管网站,以便:
https://www.example.com,http://www.example.com和http://example.com全部重定向到https://example.com
你需要:
它为什么有效?在两种情况下(使用和不使用www),CloudFront都提供从HTTP到HTTPS的重定向。 www.example.com的存储桶提供重定向到example.com。如果您没有此分发,则存储桶将无法重定向https://www.example.com的请求。 S3本身不支持静态网站托管的HTTPS。
由于这个答案,我找到了解决方案:Amazon S3 Redirect and Cloudfront
简而言之:
如果源只是存储区ID,则Cloudfront不会遵循S3中的重定向规则设置。相反,我必须将原点设置为提供的s3静态网站主机名。