Ruby on rails Rails操作\切换到amazon活动存储后没有上传文本

Ruby on rails Rails操作\切换到amazon活动存储后没有上传文本,ruby-on-rails,amazon-s3,actiontext,Ruby On Rails,Amazon S3,Actiontext,当我在action_text(使用trix编辑器)中附加图像或其他文件时,图像显示为灰色进度条,没有任何进展,文件也不会上载 我在日志中看到: Started POST "/rails/active_storage/direct_uploads" for 127.0.0.1 at 2020-09-21 14:34:32 -0400 Processing by ActiveStorage::DirectUploadsController#create as JSON Par

当我在action_text(使用trix编辑器)中附加图像或其他文件时,图像显示为灰色进度条,没有任何进展,文件也不会上载

我在日志中看到:

Started POST "/rails/active_storage/direct_uploads" for 127.0.0.1 at 2020-09-21 14:34:32 -0400
Processing by ActiveStorage::DirectUploadsController#create as JSON
  Parameters: {"blob"=>{"filename"=>"20190114_085126.jpg", "content_type"=>"image/jpeg", "byte_size"=>2865061, "checksum"=>"B2V2/VIDZ0oijiVW/57ZOQ=="}, "direct_upload"=>{"blob"=>{"filename"=>"20190114_085126.jpg", "content_type"=>"image/jpeg", "byte_size"=>2865061, "checksum"=>"B2V2/VIDZ0oijiVW/57ZOQ=="}}}
   (0.3ms)  BEGIN
  ActiveStorage::Blob Create (1.3ms)  INSERT INTO "active_storage_blobs" ("key", "filename", "content_type", "byte_size", "checksum", "created_at") VALUES ($1, $2, $3, $4, $5, $6) RETURNING "id"  [["key", "8l50q4ttoz20x6ixwvgnefodu9p6"], ["filename", "20190114_085126.jpg"], ["content_type", "image/jpeg"], ["byte_size", 2865061], ["checksum", "B2V2/VIDZ0oijiVW/57ZOQ=="], ["created_at", "2020-09-21 18:34:32.952044"]]
   (0.5ms)  COMMIT
[Aws::S3::Client 0 0.000591 0 retries] put_object(content_type:"image/jpeg",content_length:2865061,content_md5:"B2V2/VIDZ0oijiVW/57ZOQ==",bucket:"mweiser-testbucket",key:"8l50q4ttoz20x6ixwvgnefodu9p6")

  S3 Storage (1.5ms) Generated URL for file at key: 8l50q4ttoz20x6ixwvgnefodu9p6 (https://mweiser-testbucket.s3.amazonaws.com/8l50q4ttoz20x6ixwvgnefodu9p6?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIA4MREWXD52IVDRYOD%2F20200921%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20200921T183432Z&X-Amz-Expires=300&X-Amz-SignedHeaders=content-length%3Bcontent-md5%3Bcontent-type%3Bhost&X-Amz-Signature=31e7a09e7d120c56a89592e8c0a5df46a91e23a32d1af7bf1a513d013a4ab264)
Completed 200 OK in 13ms (Views: 0.2ms | ActiveRecord: 2.1ms | Allocations: 3426)
我已经通过直接调用s3(见下面的代码)进行了测试,上传工作正常

>> s3 = Aws::S3::Client.new
=> #<Aws::S3::Client>
>> res = Aws::S3::Resource.new  
=> #<Aws::S3::Resource:0x000000000a59eed0 @client=#<Aws::S3::Client>>
>> bucket = res.bucket('mweiser-testbucket')
=> #<Aws::S3::Bucket:0x000000000a735cf8 @name="mweiser-testbucket", @data=nil, @client=#<Aws::S3::Client>, @waiter_block_warned=false, @arn=nil>
>> obj = bucket.object('testfile.pdf')
=> #<Aws::S3::Object:0x000000000a759388 @bucket_name="mweiser-testbucket", @key="testfile.pdf", @data=nil, @client=#<Aws::S3::Client>, @waiter_block_warned=false>
>> result = obj.upload_file('./erd.pdf')
=> true
[Aws::S3::Client 200 0.380179 0 retries] put_object(bucket:"mweiser-testbucket",key:"testfile.pdf",body:#<File:./erd.pdf (51715 bytes)>)  
>s3=Aws::s3::Client.new
=> #
>>res=Aws::S3::Resource.new
=> #
>>bucket=res.bucket('mweiser-testbucket'))
=> #
>>obj=bucket.object('testfile.pdf')
=> #
>>结果=对象上传文件('./erd.pdf')
=>正确
[Aws::S3::Client 200 0.380179 0次重试]放置对象(bucket:“mweiser testbucket”,key:“testfile.pdf”,body:#)
瞧。。。我的文件上传了。我的凭据都在1个位置,因此这不是权限问题。action_文本与:local完美配合


我错过了什么吗?

找到了解决方案。。。铲斗的CORS设置

可在此处找到:

原来这是一个CORS问题,Chris在这里制作了一个视频:

除此之外,我还必须在S3 bucket设置中设置CORS配置。这就是最终对我起作用的配置:

<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
  <CORSRule>
    <AllowedOrigin>*</AllowedOrigin>
    <AllowedMethod>GET</AllowedMethod>
    <AllowedMethod>POST</AllowedMethod>
    <AllowedMethod>PUT</AllowedMethod>
    <AllowedHeader>*</AllowedHeader>
  </CORSRule>
</CORSConfiguration>

*
得到
邮递
放
*

这确实有效,但最好只将您的AllowedOrigination设置为您控制的来源(即您的域)。例如,使用此配置,任何人都可以将其放入并发布到您的s3存储桶中。我建议将
*
更改为
https://www.example.com