我正在尝试从URL保存文件,然后将其保存到S3。这是我编写的rake任务代码:
require 's3'
require 'open-uri'
task :testing => [:environment] do
aws_object = S3::Service.new(access_key_id: Rails.application.secrets.aws_access_key_id, secret_access_key: Rails.application.secrets.aws_secret_access_key)
bucket = aws_object.buckets.find(Rails.application.secrets.aws_bucket)
url = 'https://pbs.twimg.com/profile_images/1111729635610382336/_65QFl7B_400x400.png'
downloded_file = open(url)
new_file = bucket.objects.build('twitter.jpg')
new_file.content = (File.read downloded_file)
if new_file.save
puts "Success!"
end
end
但是当我运行上面的rake任务代码时,这就是我在终端上得到的内容:
rake aborted!
S3::Error::ResponseError: S3::Error::ResponseError
/Users/ryzal/Sites/test/lib/tasks/testing.rake:17:in `block in <top (required)>'
/Users/ryzal/.rbenv/versions/2.3.1/bin/bundle:23:in `load'
/Users/ryzal/.rbenv/versions/2.3.1/bin/bundle:23:in `<main>'
Tasks: TOP => testing
(See full trace by running task with --trace)
我已经检查了我所有的S3详细信息,并且所有信息都是正确的。有人可以帮忙吗? 谢谢!
答案 0 :(得分:0)
我终于解决了这个,这就是我的方法:
1)我使用aws-sdk-ruby宝石而不是s3
宝石
2)我参考了S3文档here,并对此进行了更新:
require 'aws-sdk-s3'
require 'open-uri'
task :testing => [:environment] do
s3 = Aws::S3::Resource.new(region: Rails.application.secrets.aws_region)
obj = s3.bucket(Rails.application.secrets.aws_bucket).object("any_unique_key_you_want_such_as_email_or_username")
url = 'https://pbs.twimg.com/profile_images/1111729635610382336/_65QFl7B_400x400.png'
file = open(url)
obj.put(body: file, acl: "public-read")
puts "URL is: #{obj.public_url}"
end