【发布时间】:2016-09-26 03:45:57
【问题描述】:
我刚刚在 AWS S3 中创建了一个新存储桶。我想在那里托管一些静态文件,但如果它们不在那里,请重定向到我的主服务器。看起来很简单,但我没有运气按照说明进行操作。
在存储桶上我已授予所有人查看权限。
我已添加存储桶策略:
{
"Version": "2012-10-17",
"Id": "Policy999999999",
"Statement": [
{
"Sid": "Stmt9999999999",
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::mybucket/*"
}
]
}
在静态网站托管上,我启用了它并创建了简单的 index.htm 和 error.htm 页面(不是我需要它们,但如果需要的话)。然后添加这些重定向规则:
<RoutingRules>
<RoutingRule>
<Condition>
<HttpErrorCodeReturnedEquals>403</HttpErrorCodeReturnedEquals>
</Condition>
<Redirect>
<Protocol>http</Protocol>
<HostName>www.mydomain.com</HostName>
<ReplaceKeyPrefixWith>/</ReplaceKeyPrefixWith>
</Redirect>
</RoutingRule>
</RoutingRules>
(如果它没有列表权限但它不适用于 403/404 的任何变体并且是否具有列表权限,则显然您需要 403 而不是 404)
当我转到不存在的存储桶上的 URL(存在的很好)时,我会得到:
<Error>
<Code>AccessDenied</Code>
<Message>Access Denied</Message>
<RequestId>9DD57C7132E76D65</RequestId>
<HostId>
I15odykUdMnGCC+hQfb1pfsnt+gkfGVxuD2sy5PrxrX16P8Njpy3yQiLLH30evTkdOOAl28HA9M=
</HostId>
</Error>
(如果列表权限打开,则为 NoSuchKey)
救命!
【问题讨论】:
标签: amazon-web-services amazon-s3 http-status-code-404 http-status-code-403