недефиниран метод `each' за #‹ActionDispatch::Http::UploadedFile:0xa5741c0›

Опитвам се да кача файл с помощта на CarrierWave и моделът на изображението е полиморфен. Но получих грешката като в заглавието, така че ето моите модели:

class Image < ActiveRecord::Base
    belongs_to :imageable, polymorphic: true

    mount_uploader :image, ImageUploader

    enum image_type: {icon: 1, title: 2, regular: 3, slider: 4}
end

class Service < ActiveRecord::Base
    has_many :images, as: :imageable, :dependent => :destroy
    accepts_nested_attributes_for :images

end

и _form.html.erb:

<div class="control-group">
   <%= simple_fields_for :images do |image| %>


     <div class="controls">
        <label class="control-label">Hizmet Büyük Resimi</label> 
        <div class="fileupload fileupload-new" data-provides="fileupload">
          <div class="fileupload-new thumbnail" style="width: 200px; height: 150px;"><img src="http://www.placehold.it/200x150/EFEFEF/AAAAAA&amp;text=no+image" alt=""/></div>
          <div class="fileupload-preview fileupload-exists thumbnail" style="max-width: 200px; max-height: 150px; line-height: 20px;"></div>
          <div>
            <span class="btn btn-file"><span class="fileupload-new">Resim Seç</span><span class="fileupload-exists">Değiştir</span>
              <%= image.input :image, input_html: { type: :file, class: "default"}, wrapper: false, label: false %>
              <%= image.input :image_type, :as => "hidden", :input_html => { :value => 2 } %>
            </span>
            <a href="/bg#" class="btn fileupload-exists" data-dismiss="fileupload">Sil</a>
          </div>
        </div>


     </div>
   <% end %>
</div>

и действието "създаване" на service_controller:

def create
    @service = Service.new(service_params)

    if @service.save
      if params[:images]
        params[:images][:image].each do |i|
          @image = @service.images.create!(:image => i, :imageable_id => @service.id, :image_type => params[i][:image_type])
        end
      end

      flash[:notice] = "Hizmet sayfası başarıyla oluşturuldu!"
      redirect_to admin_services_path
    else
      flash[:alert] = "Hizmet sayfası eklenirken bir hata oluştu. Lütfen tekrar deneyiniz!"
      render "new"
    end
  end

Съобщение за грешка:

undefined method `each' for #<ActionDispatch::Http::UploadedFile:0xa5741c0>

Rails.root: D:/Projects/TorkGarage/website/torkgarage

Application Trace | Framework Trace | Full Trace
app/controllers/admin/services_controller.rb:19:in `create'
Request

Parameters:

{"utf8"=>"✓",
 "authenticity_token"=>"yN62eOMu2gTrNIWgs27XBiA3uxIAGVgTGt4ywTSm3lKn4kEqG2Ka+3IdaqvSpRQrOPVkBBiuWLl1l5jx5fEUWw==",
 "service"=>{"service_name"=>"Rot - Balans",
 "service_description"=>"sdsad asdas&nbsp;",
 "meta_keywords"=>"adas da"},
 "_wysihtml5_mode"=>"1",
 "images"=>{"image"=>#<ActionDispatch::Http::UploadedFile:0xa5741c0 @tempfile=#<Tempfile:C:/Users/mehmet/AppData/Local/Temp/RackMultipart20150430-6992-8dc0q8.png>,
 @original_filename="Layer-6.png",
 @content_type="image/png",
 @headers="Content-Disposition: form-data; name=\"images[image]\"; filename=\"Layer-6.png\"\r\nContent-Type: image/png\r\n">,
 "image_type"=>"2"},
 "button"=>""}

И така, какво не е наред в тази ситуация?


person mehmetserif    schedule 30.04.2015    source източник
comment
.each се използва за масив, но тук в параметрите няма масив, това е хеш. така че хвърля тази грешка.   -  person Kushal    schedule 30.04.2015
comment
@Kushal така че вместо .each трябва ли да използвам .each do |key, value|?   -  person mehmetserif    schedule 30.04.2015
comment
променете params[:images][:image].each на params[:images].each, което трябва да зацикля върху обекти UploadedFile   -  person MrYoshiji    schedule 30.04.2015
comment
@MrYoshiji Опитах и ​​това, но този път получих недефиниран метод „[]“ за грешка nil:NilClass.   -  person mehmetserif    schedule 30.04.2015


Отговори (1)


Опитвате се да преминете през масив от изображения, но вашите параметри имат само едно изображение, така че корекцията е заменена:

params[:images][:image].each do |i|
  @image = @service.images.create!(:image => i, :imageable_id => @service.id, :image_type => params[i][:image_type])
end

с

@image = @service.images.create!(:image => params[:images][:image], :imageable_id => @service.id, :image_type => params[:images][:image_type])
person Aguardientico    schedule 30.04.2015
comment
Все още извиквате .each на обект UploadedFile ... което също ще повдигне NoMethodError - person MrYoshiji; 30.04.2015
comment
Да, това също не работи, решението използва ли двойка ключ - стойност? - person mehmetserif; 30.04.2015
comment
Съжалявам, лошото ми, ефектът от използването на копиране и поставяне, актуализира отговора - person Aguardientico; 30.04.2015
comment
Да, това реши проблема, но имам друг въпрос, в същия формуляр ще има повече качвания на файлове и всеки от тях е свързан с един и същ модел, но техните типове изображения са различни. Така че това време ще използва .each работа? Това е вложена форма и трябва да имам повече от един image_type... @Aguardientico - person mehmetserif; 30.04.2015
comment
Да, но ще трябва да промените html входа, за да бъде масив, искам да кажа, че вместо name='image' трябва да използвате name='image[]' - person Aguardientico; 30.04.2015
comment
@Aguardientico добре в моята ситуация, ще има 3 единични качвания и 1 многократно качване, знам, че звучи зле, но що се отнася до различните image_types моето решение ще бъде такова. Така че за множество изображения сте прав, мога да се справя с name = 'image[]', но ще има и единични. - person mehmetserif; 30.04.2015