Ответ 1
Этот вид проблематичен с точки зрения Rails из-за того, как работает загрузка изображений. Одна из стратегий, позволяющая ей работать лучше:
- Создайте подформу для загрузки изображения, возможно, используя swfupload, чтобы сделать его более упорядоченным.
- Создайте модель для получения ваших загрузок, которая включает в себя некоторый рандомизированный ключ доступа, используемый для извлечения и связывания. Скрепка скрепляет прикрепленный файл.
- Используйте AJAX для заполнения вашей основной формы, вставив скрытое поле или потенциально видимый элемент флажка с соответствующей уникальной кнопкой, когда заканчивается подформация.
Типичная модель выглядит примерно так:
class Avatar < ActiveRecord::Base
has_attached_file :image
# ... Additional Paperclip options here
before_validation :assign_unique_key
belongs_to :user
def to_param
self.unique_key
end
protected
def assign_unique_key
return if (self.unique_key.present?)
self.unique_key = Digest::SHA1.hexdigest(ActiveSupport::SecureRandom.random_number(1<<512).to_s)
end
end
Причиной для поля unique_key является то, что вы можете связать это с формой потенциально несохраненной записи. Преимущественно использовать unique_key вместо id при размещении в URL-адресах, так как трудно определить, должен ли пользователь видеть это изображение или нет, когда он загружен, поскольку пользователь-владелец еще не может быть назначен.
Это также запрещает любопытным людям изменять какой-то последовательный, легко угаданный идентификатор в вашем URL-адресе и видеть другие загруженные аватары.
Вы можете получить окончательный уменьшенный URL-адрес миниатюры для Аватара, как и любой модели на данный момент.
Вы можете легко отключить параметры при получении и перевести обратно на идентификационные номера аватаров:
# If an avatar_id parameter has been assigned...
if (params[:user][:avatar_id])
# ...resolve this as if it were a unique_key value...
avatar = Avatar.find_by_unique_key(params[:user][:avatar_id])
# ...and repopulate the parameters if it has been found.
params[:user][:avatar_id] = (avatar && avatar.id)
end
# ... params[:user] used as required for create or update
Когда люди загружают и повторно загружают изображения, в конечном итоге у вас будет большое количество потерянных записей, которые фактически не используются нигде. Просто написать задачу рейка, чтобы очистить все это после того, как прошло разумное количество времени. Например:
task :purge_orphan_avatars => :environment do
# Clear out any Avatar records that have not been assigned to a particular
# user within the span of two days.
Avatar.destroy_all([ 'created_at<? AND user_id IS NULL', 2.days.ago ])
end
Использование destroy_all должно также повлиять на очистку всего материала Paperclip.