Скрепка, Rails 2.3.3 и OSX - PullRequest
       24

Скрепка, Rails 2.3.3 и OSX

0 голосов
/ 26 августа 2009

У меня есть код

в поле зрения

<% uberform_for :profile, :html => { :multipart => true, :method => :put }, :url => update_avatar_path do |f| %>
  <%= f.file_field :avatar %>

  <p><%= f.submit 'Upload avatar' %></p>
<% end %>

в контроллере

  def update_avatar
    current_user.profile.update_attribute(:avatar, params[:avatar])
    redirect_to user_path(current_user)
  end

и в модели

class Profile < ActiveRecord::Base
  attr_accessible :first_name, :last_name, :nickname
  has_attached_file :avatar, :styles => {:thumb => '100x100>'},
    :path => '#{RAILS_ROOT}/public/images/avatars/:id/:normalized_basename_:style.:extension',
    :url => '/images/avatars/:id/:normalized_basename_:style.:extension'

  validates_attachment_content_type :avatar, :content_type => ['image/jpeg', 'image/png', 'image/gif']
  validates_attachment_size :avatar, :less_than => 1.megabytes
end

А когда я пытаюсь загрузить аватар - ничего не приходит в БД и в файловую систему. В логах я вижу

Processing UsersController#update_avatar (for 127.0.0.1 at 2009-08-26 11:09:04) [PUT]
  Parameters: {"profile"=>{"avatar"=>#<File:/var/folders/zg/zghNxzjrFP02se1nq1fKQ++++TI/-Tmp-/RackMultipart20090826-3425-1akehpx-0>}, "authenticity_token"=>"Frf1ozk01ePIhvsPSX3k1ophgvHHrnBFKhFcF21co+o="}
  User Load (0.5ms)   SELECT * FROM "users" WHERE ("users"."id" = 1) LIMIT 1
  Profile Load (0.4ms)   SELECT * FROM "profiles" WHERE ("profiles".user_id = 1) LIMIT 1
[paperclip] Saving attachments.
Redirected to http://localhost:3000/users/alec-c4
Completed in 18ms (DB: 1) | 302 Found [http://localhost/update_avatar]

и приложение отображает картинку /avatars/thumb/missing.png

Как это решить?

Ответы [ 2 ]

1 голос
/ 26 августа 2009

params[:avatar] отсутствует в хэше params. Вам нужно будет использовать params[:profile][:avatar]

0 голосов
/ 26 августа 2009

Я обнаружил, что существует конфликт с плагином http://github.com/netguru/paperclip-extended/tree/master. Удаление этого плагина приводит к тому, что приложение работает нормально.

...