载波多图一键上传

carrierwave multiple image upload with one button

我的问题从开始。 我正在使用 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我要做什么?

仔细查看后,您遇到了多个问题,首先:

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

应该是:

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

( form_tag 参数的结构与 form_for 有点不同)

然后您需要指示 rails 将您的文件作为数组放入 params 中,您可以通过使用表单元素的名称约定来实现。所以而不是:

 <%= 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

希望对您有所帮助。