繁体   English   中英

Rails Image使用carrierwave和fog上传到S3

[英]Rails Image Upload to S3 with carrierwave and fog

你好我一直在开发一个Web应用程序我想让用户上传个人资料图片。 我花了很多时间试图让运载波和雾与s3一起工作,但还没有成功完成它。 你能给我的任何帮助都是非常苛刻的。

更新:我一直试图摆弄它,从我可以告诉文件永远不会上传,:图像值在用户控制器中始终为空。

我的上传课程。

class PhotoUploader < CarrierWave::Uploader::Base
   storage :fog
   def store_dir
      "uploads/#images/#{model.class.to_s.underscore}"
   end
end

雾初始化器

CarrierWave.configure do |config| 
  config.fog_credentials = { 
    :provider               => 'AWS', 
    :aws_access_key_id      => 'xxx', 
    :aws_secret_access_key  => 'yyy', 
  } 
  config.fog_directory  = 'pictures_dev' 
  config.fog_public     = true
  config.fog_attributes = {'Cache-Control'=>'max-age=315576000'}
end 

用户模型

class User
  include Mongoid::Document
  ....
  has_one :photo
  ....
end

照片模型

class Photo
include Mongoid::Document
attr_accessible :name, :image

field :image, :type => String
field :name, :type => String

belongs_to :user

mount_uploader :image, PhotoUploader
 end

照片控制器

  class PhotoController < ApplicationController

    def update
    @photo = Photo.find(params[:id])
      if @photo.update_attributes(params[:image]) 
        flash[:success] = "Your have updated your settings successfully."
      else
        flash[:error] = "Sorry! We are unable to update your settings. Please check your      fields and try again."
    end
    redirect_to(:back)
   end

上传表格

= form_for @photo, :html => {:multipart => true} do |f|
  %p
    %label Photo
    = image_tag(@user.image_url) if @photo.image? 
    = f.file_field :image
    = f.submit

这是我能想到的所有相关内容,如果有人需要我发布更多代码我会很高兴。 老实说,我很难过,任何帮助都表示赞赏。

我设法为任何感兴趣的人找出问题。 事实上,我正在使用设备与我的用户,并且需要在上传表单中有一些不同的配置才能使其正常工作。 以下是帮助我的文档的链接,以防有其他问题。

https://github.com/jnicklas/carrierwave/wiki/How-to%3A-use-carrierwave-with-devise

我觉得你有问题

if @photo.update_attributes(params[:image])

尝试这样的事情

if @photo.update_attributes(image: params[:photo][:image])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM