gpt4 book ai didi

ruby-on-rails - Carrierwave 保存对象而不是数据库中的文件名或 mount_uploader 不起作用

转载 作者:数据小太阳 更新时间:2023-10-29 08:02:39 25 4
gpt4 key购买 nike

我使用 Carrierwave gem 上传文件,但我遇到了问题。 Controller 不会将头像保存在数据库中,尽管该对象来自 View 的参数。如果我从我的模型中删除 mount_uploader,Carrierwave 会在数据库中保存对象而不是文件名。我该如何解决?

我的 user_controller.rb

  class UsersController < ApplicationController

before_action :set_user

def show
end

def edit
end

def update
if @user.update(users_params)
redirect_to user_path(current_user.id)
else
puts @user.inspect
flash.now[:alert]= 'Something wrong'
render :edit
end
end
def set_user
@user = User.find(params[:id])
end

def users_params
params.require(:user).permit(:avatar)
end

def new
end


end

我的 user.rb 模型

 class User < ApplicationRecord
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable, :omniauthable,
omniauth_providers: [:facebook]

has_one :account, dependent: :destroy
mount_uploader :avatar, AvatarUploader
end

编辑.html.haml

.container
%h1 Edit
= form_for @user, html: { :multipart => true } do |f|
= f.label :id
= f.file_field :avatar
= f.submit

avatar_uploader.rb

  class AvatarUploader < CarrierWave::Uploader::Base
include CarrierWave::MiniMagick
storage :file

def store_dir
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
end

version :thumb do
process resize_to_fit: [50, 50]
end

def extension_whitelist
%w(jpg jpeg gif png)
end
end

最佳答案

对象正在保存在数据库中,因为您在参数中传递了完整的头像对象。

安装 uploader 之后

class User < ActiveRecord::Base
mount_uploader :avatar, AvatarUploader
end

并创建并保存一个新用户

u = User.new
u.avatar = params[:file] # Assign a file like this
u.save!

整个头像对象被分配,然后您可以访问该对象的各种方法来获取字段,如:

u.avatar.url # => '/url/to/file.png'
u.avatar.current_path # => 'path/to/file.png'
u.avatar_identifier # => 'file.png'

如果你只想在数据库中保存文件名,而不是将 avatar 传递给用户参数,你可以只传递 avatar.identifier

相应的文件仍将由头像 uploader 存储

或者您可以自己创建 uploader 实例,例如:

uploader = AvatarUploader.new
uploader.store!(my_file)

更新:由于您使用的是 Devise,因此您必须以不同的方式访问参数。所以 User.rb 应该是这样的:在 Rails 5 中:

class User < ActiveRecord::Base
mount_uploader :avatar, AvatarUploader

devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable

# Setup accessible (or protected) attributes for your model
attr_accessible :email, :password, :remember_me, :avatar, :avatar_cache, :remove_avatar
end

Rails 4 中:而不是模型中的 attr_accessible,params 必须在应用程序 Controller 中列入白名单

class ApplicationController < ActionController::Base
before_filter :configure_permitted_parameters, if: :devise_controller?

protected

def configure_permitted_parameters
devise_parameter_sanitizer.permit(:sign_up) { |u| u.permit(:username, :email, :password,
:password_confirmation, :remember_me, :avatar, :avatar_cache, :remove_avatar) }
devise_parameter_sanitizer.permit(:account_update) { |u| u.permit(:username, :email, :password,
:password_confirmation, :current_password, :avatar, :avatar_cache, :remove_avatar) }
end
end

关于ruby-on-rails - Carrierwave 保存对象而不是数据库中的文件名或 mount_uploader 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44048061/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com