我正在尝试从生产服务器访问我的S3存储桶。一切都在开发中很好,但是在我的产品控制台中我得到了:
Aws::S3::Errors::AuthorizationHeaderMalformed: The authorization header is malformed; the Credential is mal-formed; expecting "<YOUR-AKID>/YYYYMMDD/REGION/SERVICE/aws4_request".
我的代码:
class AwsFileDownloader
def initialize(args)
@s3 = Aws::S3::Client.new
@aws_file_path = ...
end
def get_file
temp_file = File.new('temp.csv', 'r+')
@s3.get_object({bucket: Rails.application.secrets.aws_bucket, key: @aws_file_path}, target: temp_file)
...
end
end
我的aws初始化程序(在两种环境下似乎都能正常工作):
require 'aws-sdk'
Aws.config.update({
region: Rails.application.secrets.aws_region,
credentials: Aws::Credentials.new(Rails.application.secrets.access_key_id, Rails.application.secrets.secret_access_key)
})
欣赏任何建议!
答案 0 :(得分:2)
要检查的事项:
答案 1 :(得分:1)
这个答案很晚,但是也许有人会觉得有用。当您切换AWS KEY ID
和AWS ACCESS KEY
时,会导致上述错误。
在正确的位置使用正确的凭据,它应该可以解决您的问题。
答案 2 :(得分:0)
由于错误表明未正确设置凭据。一个可能的原因(因为在开发环境中工作)是配置变量access_key_id和secret_access_key可能是特定于环境的。
答案 3 :(得分:0)
也有同样的错误,但是问题是我错误地交换了访问密钥和秘密密钥的值。