gpt4 book ai didi

ruby-on-rails - Rails 4 - Carrierwave 图像未上传

转载 作者:行者123 更新时间:2023-12-04 20:55:48 26 4
gpt4 key购买 nike

更新 : 感谢大家帮忙解决这个问题。我决定放弃学习,并在配置文件模型中添加了另一个图像属性。现在必须这样做。

我正在尝试在 rails 4 中制作一个应用程序。

我有一个用户模型,它有一个头像属性。

我也有一个配置文件模型。

用户:有一个个人资料
个人资料:属于用户

我拆分它们的原因是因为配置文件包含所有变量,而用户包含所有固定属性,未经管理员许可无法更改。

异常(exception)是我的用户模型有一个头像(图像)属性,我希望允许用户更改。

我的代码的其他部分有用户载波,它可以工作。但是,在这个用例中有些地方是错误的。

我有一个头像上传器:

class AvatarUploader < CarrierWave::Uploader::Base

# Include RMagick or MiniMagick support:
# include CarrierWave::RMagick
include CarrierWave::MiniMagick

# Choose what kind of storage to use for this uploader:
# storage :file
storage :fog

# Override the directory where uploaded files will be stored.
# This is a sensible default for uploaders that are meant to be mounted:
def store_dir
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
end

def cache_dir
"#{Rails.root}/tmp/uploads"
end

# Provide a default URL as a default if there hasn't been a file uploaded:
# def default_url
# # For Rails 3.1+ asset pipeline compatibility:
# # ActionController::Base.helpers.asset_path("fallback/" + [version_name, "default.png"].compact.join('_'))
#
# "/images/fallback/" + [version_name, "default.png"].compact.join('_')
# end

# Process files as they are uploaded:
# process :scale => [200, 300]
#
# def scale(width, height)
# # do something
# end

# Create different versions of your uploaded files:
# version :thumb do
# process :resize_to_fit => [50, 50]
# end

process :resize_to_fit => [800, 800]
# Create different versions of your uploaded files:
version :thumb do
process :resize_to_fill => [200,200]
end

version :profile do
process :resize_to_fill => [345,245]
end

version :wide do
process :resize_to_fill => [951,245]
end

version :preview do
process :resize_to_fill => [90,90]
end

version :small do
process :resize_to_fill => [35,35]
end


# Add a white list of extensions which are allowed to be uploaded.
# For images you might use something like this:
def extension_white_list
%w(jpg jpeg gif png)
end

# Override the filename of the uploaded files:
# Avoid using model.id or version_name here, see uploader/store.rb for details.
# def filename
# "something.jpg" if original_filename
# end

end

在我的用户模型中,我有:
class User < ActiveRecord::Base
mount_uploader :avatar, AvatarUploader
end

在我的用户 Controller 中 - 我在强参数中将 :avatar 列入白名单。

在我的配置文件 Controller 强参数中,我尝试添加:
params.require(:profile).permit(:title, :overview, user_attributes: [:avatar])

我还尝试在我的个人资料模型中允许用户属性(如下):
belongs_to :user
accepts_nested_attributes_for :user

我的 View 用户文件夹中有一个部分表单。
<%= simple_fields_for :user,  html: { multipart: true } do |f| %>
<%= f.error_notification %>
<div class="form-inputs">
<%= f.input :avatar, as: :file, :label => "Add a profile image (head shot)" %>
</div>
<% end %>

该部分包含在我的个人资料表格中。

然后我想在我的个人资料显示 View 中显示用户头像:
<div class="col-md-5 col-lg-4 vc-photo" style= "background-image: url(<%= image_url @profile.user.avatar.url if @profile.user.avatar? %>);">&nbsp;</div>

但是,它只会呈现空白。

我试过:

);">

但它仍然只是呈现空白。

谁能看到我做错了什么?

当我尝试通过检查 user.avatar 在 rails 控制台中进行测试时,我得到以下信息:

u.avatar
=> #,last_sign_in_ip:#,confirmation_token:“73abb47df224dbc3a612b46ced66e1aba...”,confirmed_at:“2016-04-02 07:13:57”,confirmation_sent_at:“2016-04-02:4firmed”,57 testiest@gmail.com”,failed_attempts:0,unlock_token:nil,locked_at:nil,created_at:“2016-04-02 07:13:57”,updated_at:“2016-04-02 22:59:43”,头像: nil, 批准: false>, @mounted_as=:avatar>

接受以下建议

我更改了我的表格,以便个人资料表格现在具有:
  <%= render 'users/profileimgform', f: f %>

users/profileimgform 现在有:
<%= simple_fields_for :user,  html: { multipart: true } do |ff| %>
<%= f.error_notification %>

<div class="form-inputs">


<%= ff.input :avatar, as: :file, :label => "Add a profile image (head shot)" %>

</div>


<% end %>

我不确定是否需要将 'ff' 合并到我的个人资料表单中的行中。我尝试用 'ff' 替换最后一个 'f',但出现错误,询问我是否应该是单个 'f'。

当我尝试这个时,控制台仍然显示 user.avatar 是“nil”。

最佳答案

我猜你对这段代码有错误:

<%= simple_fields_for :user,  html: { multipart: true } do |f| %>
<%= f.error_notification %>
<div class="form-inputs">
<%= f.input :avatar, as: :file, :label => "Add a profile image (head shot)" %>
</div>
<% end %>

查看生成的html。我认为应该有这样的事情:
<%= simple_form_for :profile do |f| %>
...
<%= f.simple_fields_for :user do |ff| %>
<%= ff.input :avatar %>
<% end %>
<% end %>

关于ruby-on-rails - Rails 4 - Carrierwave 图像未上传,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36379620/

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