载波多个图像上传一个按钮

时间:2015-12-26 17:25:47

标签: ruby-on-rails carrierwave image-uploading

我的问题从here开始。 我使用Sqlite3,我的模型关系看起来像这样。

class ImagePost < ActiveRecord::Base
    has_many :attachments
end

我的附件

class Attachment < ActiveRecord::Base
    belongs_to :image_post
    mount_uploader :img, S3uploaderUploader
end

问题是我想让我的用户只用一个按钮上传他们的图像。现在,我做了

<%= form_tag img_upload_create_path, method: "POST", html: { multipart: true } do %>
        <%= hidden_field_tag("image_post_id", @image_post.id ) %>
        <%= hidden_field_tag("user_id", current_user.id ) %>

        <%= file_field_tag 'user_pic', multiple: true, accept: 'image/png,image/gif,image/jpeg' %>

        <%= submit_tag "image-upload", :class => "btn btn-primary btn-lg" %>
      <% end %>

我的image_upload控制器,

class ImgUploadController < ApplicationController
  def create
    @user_img = Attachment.create(
        hasuk_house_id: params[:image_post_id],
        user_id: current_user.id,
        img: params[:user_pic]
        )
  end
end

但是当我提交文件时,@user_img.img = nil我该怎么办?

1 个答案:

答案 0 :(得分:1)

仔细观察之后,你会遇到多个问题,首先是:

<%= form_tag(img_upload_create_path, { multipart: true, method: "POST"})

应该是:

form_tag

form_for参数的结构与params

略有不同

然后你需要指示rails将你的文件作为数组放在 <%= file_field_tag 'user_pic', multiple: true, accept: 'image/png,image/gif,image/jpeg' %> 中,你可以通过使用表单元素的名称约定来实现。所以代替:

<%= file_field_tag 'user_pic[]', multiple: true, accept: 'image/png,image/gif,image/jpeg' %>

你需要:

params[:user_pic]

最后在您的控制器中,您将拥有params[:user_pic].each do |pic| Attachment.create( hasuk_house_id: params[:image_post_id], user_id: current_user.id, img: pic ) end 中的一个数组文件,因此您必须遍历它并为每个文件创建附件:

(opacity=0)

希望有所帮助。