我正在尝试使用重定向规则设置静态web托管。在我的应用程序中,任何具有前缀api/(http://web.company.com/api)的请求都应该重定向到具有相同前缀(http://api.company.com/api)的另一个主机。我已按以下方式设置路由规则:
<RoutingRules>
<RoutingRule>
<Condition>
<KeyPrefixEquals>api/</KeyPrefixEquals>
</Condition>
<Redirect>
<HostName>api.company.com</HostName>
</Redirect>
</RoutingRule>
</RoutingRules>
但请求没有被正确重定向。控制台中有两个不同的错误:
XMLHttpRequest无法加载http://api.company.com/api/logout。请求的资源上没有“access-control-allow-origin”标头。因此,不允许访问来源“http://bucket.s3-website-us-west-2.amazonaws.com”。
Angular.js:10661 POST http://bucket.s3-website-us-west-2.amazonaws.com/api/oauth/token?grant_type=client_credentials 405(不允许使用方法)
因为其中一个问题是CORS问题,这里是我的CORS配置:
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>http://*</AllowedOrigin>
<AllowedOrigin>https://*</AllowedOrigin>
<AllowedMethod>GET</AllowedMethod>
<MaxAgeSeconds>3000</MaxAgeSeconds>
<AllowedHeader>*</AllowedHeader>
</CORSRule>
</CORSConfiguration>
看起来对/api/something的请求被重定向(但被浏览器拒绝),而/api/something/else没有被重定向。我做错什么了?
我遇到了类似的问题。我建立了两个静态网站。一个是根域。第二个是子域。我们需要从根到子域的重定向。我们使用了如下语法:
<RoutingRules>
<RoutingRule>
<Condition>
<KeyPrefixEquals>api/</KeyPrefixEquals>
</Condition>
<Redirect>
<HostName>api.company.com</HostName>
<Protocol>https</Protocol>
<ReplaceKeyWith>index.html</ReplaceKeyWith>
</Redirect>
</RoutingRule>
</RoutingRules>
文档,虽然不是很清楚,但可以在这里找到:http://docs.aws.amazon.com/amazons3/latest/dev/howdoiwebsiteconfiguration.html#configure-bucket-as-website-routing-rule-syntax