gpt4 book ai didi

ruby-on-rails - CORS 与 Amazon S3 和 Cloudfront

转载 作者:行者123 更新时间:2023-12-04 02:23:33 24 4
gpt4 key购买 nike

我有一个托管在 Heroku 上的 Rails 应用程序,它使用 CloudFront 和托管在 S3 上的 Assets 。

它完美地显示了 Assets (虽然花了一些力气)。

我的 Cloudfront 设置:

Forward Headers: Whitelist
Whitelist Headers: Origin
Forward Query Strings: No

S3 存储桶的 CORS 设置:

<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>*</AllowedOrigin>
<AllowedMethod>GET</AllowedMethod>
<AllowedMethod>HEAD</AllowedMethod>
<AllowedHeader>*</AllowedHeader>
</CORSRule>
</CORSConfiguration>

调用图片的JS(咖啡)

@mousemove (e) ->
ctx = $("<canvas>").attr(
width: @width
height: @height
)[0].getContext("2d")

ctx.drawImage(this, 0, 0, @width, @height)

# This is because firefox doesn't support offset[X|Y]
if(e.offsetX == undefined)
xpos = e.pageX - $(this).offset().left;
ypos = e.pageY - $(this).offset().top;
else
xpos = e.offsetX;
ypos = e.offsetY;

e.rgb = ctx.getImageData(xpos, ypos, 1, 1).data
return f.call this, e

此错误:未捕获的安全错误:无法在“CanvasRenderingContext2D”上执行“getImageData”: Canvas 已被跨源数据污染。

curl 请求:

curl -i -H "来源:http://example.com/"http://randomness.cloudfront.net/franchisees/logos/000/000/006/icon/Screen_Shot_2014-08-06_at_15 .21.14.png?1407334881

  Response:
HTTP/1.1 200 OK
Content-Type: image/png
Content-Length: 6888
Connection: keep-alive
Date: Wed, 06 Aug 2014 16:15:54 GMT
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: GET, HEAD
Last-Modified: Wed, 06 Aug 2014 14:21:23 GMT
ETag: "6f266467cf0a570526869bcf280da412"
Accept-Ranges: bytes
Server: AmazonS3
Age: 21
Vary: Origin
X-Cache: Hit from cloudfront
Via: 1.1 16d4ae36524b457e558b982004526450.cloudfront.net (CloudFront)
X-Amz-Cf-Id: 5Vm_eCn_lTOHEMzPEcmtCGYCUdOZ2r_9R4W6mEPTOPFUIJe0ilMP7g==

*snip*

这不是缓存问题我每次都使用新图像,尽管这个请求是在缓存版本上。

我知道有变通办法,但我真的希望它能以这种方式工作。

我在这里错过了什么?

最佳答案

问题是默认情况下浏览器不会检查这些 cors header - 所有拉入的图像都是脏的。为了让您的 cors header 执行任何操作,您需要在 img 上设置 crossorigin 属性,以便获得 cors enabled image。 .

<img src="blah" crossorigin="anonymous" />

crossorigin 属性可以取值 anonymoususe-credentials。这类似于发出跨域 ajax 请求时的 withCredentials 选项:默认情况下不会发送 cookie、http auth 等。如果您在 javascript 中创建图像,则相应的属性是 crossOrigin

根据MDN documentation Chrome、Firefox 和 IE 11 支持此功能,但已发布的 Opera 或 Safari 版本不支持

关于ruby-on-rails - CORS 与 Amazon S3 和 Cloudfront,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25165433/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com