【问题标题】:Rails: save file from URL and save it to Amazon S3Rails:从 URL 保存文件并将其保存到 Amazon S3
【发布时间】:2013-03-02 23:13:31
【问题描述】:

从给定 URL 下载文件并立即将其上传到 Amazon S3 的更直接的方法是什么(+ 将有关文件的一些信息保存到数据库中,例如名称、大小等)?

现在,我既没有使用 Paperclip,也没有使用 Carrierwave。

谢谢

【问题讨论】:

    标签: ruby-on-rails ruby upload amazon-s3 download


    【解决方案1】:

    直截了当:

    require 'open-uri'
    require 's3'
    
    amazon = S3::Service.new(access_key_id: 'KEY', secret_access_key: 'KEY')
    bucket = amazon.buckets.find('image_storage')
    url = 'http://www.example.com/url'
    download = open(url)
    
    file = bucket.objects.build('image.png')
    file.content = (File.read download)
    
    if file.save
      # Make a new ActiveRecord::Base class for this
      LogFile.create(size: download.size, type: download.type, name: url)
    end
    

    https://github.com/qoobaa/s3

    【讨论】:

    • 你在哪里写这个?
    • 在纯文本文件中,然后使用$ ruby file.rb (?) 运行它
    • 是的,但我对您的解决方案非常感兴趣,我想将其插入我的网站以存储来自鸟舍的图片。我创建了另一个问题:Save a picture in S3 from a temporary URL
    • 您可以将此代码放入任何控制器操作中,或任何您认为合适的地方。例如,您可以制作一个表单来提交一个操作的 url,并将其作为替换 url 变量的参数
    猜你喜欢
    • 2015-12-05
    • 2012-11-02
    • 2017-10-08
    • 1970-01-01
    • 1970-01-01
    • 2014-04-06
    • 2011-01-31
    • 1970-01-01
    • 2016-03-31
    相关资源
    最近更新 更多