AWS s3从rails应用程序访问PRIVATE bucket url



我是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)

相关内容

  • 没有找到相关文章

最新更新