bnz*_*ner 10 ruby acl ruby-on-rails amazon-s3 aws-sdk
在我的Rails应用程序中,我在创建时将客户RMA运输标签保存到S3存储桶.我刚刚更新到aws-sdk gem的V2,现在我设置ACL的代码不起作用.
在V1.X中运行的代码:
# Saves label to S3 bucket
s3 = AWS::S3.new
obj = s3.buckets[ENV['S3_BUCKET_NAME']].objects["#{shippinglabel_filename}"]
obj.write(open(label.label('pdf').postage_label.label_pdf_url, 'rb'), :acl => :public_read)
Run Code Online (Sandbox Code Playgroud)
.write似乎已被弃用,所以我现在正在使用.put.一切正常,除非我尝试设置ACL.
V2.0的新代码:
# Saves label to S3 bucket
s3 = Aws::S3::Resource.new
obj = s3.bucket(ENV['S3_BUCKET_NAME']).object("#{shippinglabel_filename}")
obj.put(Base64.decode64(label_base64), { :acl => :public_read })
Run Code Online (Sandbox Code Playgroud)
我得到一个Aws::S3::Errors::InvalidArgument错误,指向ACL.
kev*_*inw 17
这段代码适合我:
photo_obj = bucket.object object_name
photo_obj.upload_file path, {acl: 'public-read'}
Run Code Online (Sandbox Code Playgroud)
所以你需要为acl使用字符串'public-read'.我通过在object.rb中看到一个例子找到了这个