我是RoR的新手。
我正在创建一个小应用程序,它可以上传图像并将其保存在S3中,用户无法将所有图像附加在zip文件中并通过电子邮件发送,以使用rubyzipgem来实现这一点。
在本地,它运行良好(我遵循gem文档(
https://github.com/rubyzip/rubyzip/
但在生产中,对于"ZIP"操作,我需要提供一个源文件夹(其中保存了图像(,由于我所有的图像都保存在s3 bucket中,我给出了如下路径:
folder = 'https://'bucket-name'.s3.amazonaws.com/'
经过研究,我喜欢类似的案例,但没有一个对我有效,例如我尝试过如何用S3的Rails Active Storage检索附件url,它给了我"没有这样的文件或目录">
2018-11-15T00:44:27.082416+00:00 app[web.1]: I, [2018-11-15T00:44:27.082337 #4] INFO -- : [db52fa26-32c2-4f7e-a766-7d39fd3ef062] Completed 500 Internal Server Error in 1532ms (ActiveRecord: 21.4ms)
2018-11-15T00:44:27.082915+00:00 app[web.1]: F, [2018-11-15T00:44:27.082844 #4] FATAL -- : [db52fa26-32c2-4f7e-a766-7d39fd3ef062]
2018-11-15T00:44:27.082988+00:00 app[web.1]: F, [2018-11-15T00:44:27.082916 #4] FATAL -- : [db52fa26-32c2-4f7e-a766-7d39fd3ef062] Errno::ENOENT (No such file or directory @ rb_file_s_lstat - https://bucket-name.s3.amazonaws.com):
2018-11-15T00:44:27.083054+00:00 app[web.1]: F, [2018-11-15T00:44:27.082985 #4] FATAL -- : [db52fa26-32c2-4f7e-a766-7d39fd3ef062]
我的bucket是私有的,所以,在我提供正确的凭据之前,它不允许我访问它,这是我不知道如何在url中发送签名以进行身份验证的部分。我尝试过类似以下的东西,但它一直给我奇怪的模拟
kDate = OpenSSL::HMAC.digest('sha256', "AWS4" + secret_access_key, dateStamp)
kRegion = OpenSSL::HMAC.digest('sha256', kDate, regionName)
kService = OpenSSL::HMAC.digest('sha256', kRegion, serviceName)
signature = OpenSSL::HMAC.digest('sha256', kService, "aws4_request")
puts("#{s3_base_url}?AWSAccessKeyId=#{access_key_id}
&Expires=#{expiration_date}
&Signature=#{signature}")
这是我打印签名时的结果
https://bucket-name.s3.amazonaws.com?AWSAccessKeyId=my-access-key
&Expires=1542416076
&Signature=Q�����>�9`o���r}�9��`�m��g��
Ps。我还创建了一个具有管理员权限的IAM用户
谢谢,我使用的是ruby 2.5.1和rails 5.2.0我是亚马逊的新手,所以如果我的问题是显而易见的,请原谅
我不确定是否要手动构建签名的URL;我从来没有尝试过。然而,AWS gem有一个用于S3对象的presigned_url
方法,它将为您构建它们。然后,您可以使用该URL访问私有存储桶中的对象。
请参阅https://docs.aws.amazon.com/sdk-for-ruby/v3/api/Aws/S3/Object.html#presigned_url-实例方法
bucket = Aws::S3::Bucket.new bucket_name
object = bucket.object object_key
object.presigned_url(:get, expires_in: expiry)