Paperclip尝试上传内容长度为0的图片

时间:2012-11-24 20:35:35

标签: ruby-on-rails paperclip

我正在尝试使用paperclip和AWS S3存储上传图像

我已经设置了回形针的默认配置

config.paperclip_defaults = {
  :storage => :s3,
  :bucket => '<bucket_name>',
  :s3_credentials => Rails.root.join('config', 'aws.yml').to_s
}

在我的模特中我有这个

as_attached_file :img, :styles => { :medium => "300x300>", :thumbnail => "100x100>" }, :path => "assets/products/:attachment/:id/:style.:extension"

在控制器中,我有一个简单的属性更新,因为我的模型是首次创建的,并且在上传图像之后:

def upload_thumbnail
   @product = Product.find(params[:id])

   if @product.update_attribute(:img, params[:image])
    render :json => { :done => true, :img_path => @product.img.url }
   else
    render :json => @product.errors }
   end
end

当我上传图片时,我会在控制台中收到此错误

[paperclip] Saving attachments.
[paperclip] saving assets/products/imgs/10/original.jpg
[AWS S3 200 4.134236 3 retries] put_object(:acl=>:public_read,:bucket_name=>"<bucket_name>",:content_length=>0,:content_type=>"image/jpeg",:data=>Paperclip::UploadedFilAdapter: image.jpg,:key=>"assets/products/imgs/10/original.jpg") AWS::Core::Client::NetworkError AWS::Core::Client::NetworkError

在S3中查看图像是在指定的路径上创建的,其大小设置为0字节。 此外,我注意到当插件试图调整图像大小时我得到了这个

[paperclip] Error while determining content type: Cocaine::CommandNotFoundError

但原始图片应正确上传。 我做错了什么?

0 个答案:

没有答案