Ruby on rails Rails回形针上载不工作。。。没有抛出错误,回滚事务
编辑:通过将模型更改为以下内容,我已设法使其开始抛出错误:Ruby on rails Rails回形针上载不工作。。。没有抛出错误,回滚事务,ruby-on-rails,paperclip,Ruby On Rails,Paperclip,编辑:通过将模型更改为以下内容,我已设法使其开始抛出错误: class User < ApplicationRecord has_secure_password has_attached_file :avatar, :path => ":rails_root/public/system/:attachment/:id/:basename_:style.:extension", :url => "/system/:attachm
class User < ApplicationRecord
has_secure_password
has_attached_file :avatar,
:path => ":rails_root/public/system/:attachment/:id/:basename_:style.:extension",
:url => "/system/:attachment/:id/:basename_:style.:extension",
:styles => {
:thumb => ['100x100#', :jpg, :quality => 70],
:preview => ['480x480#', :jpg, :quality => 70],
:large => ['600>', :jpg, :quality => 70],
:retina => ['1200>', :jpg, :quality => 30]
},
:convert_options => {
:thumb => '-set colorspace sRGB -strip',
:preview => '-set colorspace sRGB -strip',
:large => '-set colorspace sRGB -strip',
:retina => '-set colorspace sRGB -strip -sharpen 0x0.5'
}
validates_attachment :avatar,
:presence => true,
:size => { :in => 0..10.megabytes },
:content_type => { :content_type => /^image\/(jpeg|png|gif|tiff)$/ }
belongs_to :leitung
def admin?
self.role == "Admin"
end
def al?
self.role == "Al"
end
end
(作品开始:)我正在设置回形针(使用ImageMagick),这样我的应用程序上的用户就可以为他们的账户上传头像。化身应该保存在本地服务器上(说出我的PC,因为应用程序目前正在开发中)。我按照GitHub上的文档设置了回形针。一切似乎都在运转。。。直到我尝试上传一张图片。提交后(在本例中,编辑现有用户以添加图像,但在创建新用户时也会发生同样的情况),它不会抛出错误或任何东西,只是重新加载页面并使提交按钮变灰。控制台中将显示以下消息:
Started PUT "/leiter/edit" for 127.0.0.1 at 2016-12-31 18:33:19 +0000
ActiveRecord::SchemaMigration Load (0.1ms) SELECT "schema_migrations".* FROM "schema_migrations"
Processing by Leiter::UsersController#update as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"RjjDgMQESgZ/9DVXTWoTvJDitAmYXqfMyVJJyKpXDsp3hE0dejJ6erMlV+wsFEH9bFlz7ZsvBlgPO63o8PkpYw==", "user"=>{"first_name"=>"Admin", "last_name"=>"Admin", "pfadi_name"=>"Admin", "email"=>"admin@application.com", "leitung_id"=>"6", "role"=>"Admin", "avatar"=>#<ActionDispatch::Http::UploadedFile:0x00000003671238 @tempfile=#<Tempfile:/tmp/RackMultipart20161231-3455-mekx7p.jpg>, @original_filename="nobody_m.original.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"user[avatar]\"; filename=\"nobody_m.original.jpg\"\r\nContent-Type: image/jpeg\r\n">}, "commit"=>"Speichern"}
User Load (0.2ms) SELECT "users".* FROM "users" WHERE "users"."id" = ? LIMIT ? [["id", 1], ["LIMIT", 1]]
(0.1ms) begin transaction
Command :: PATH=/usr/local/bin/:$PATH; file -b --mime '/tmp/3068f4f020f8c43d300b1e06b58b829b20161231-3455-1vvcs8q.jpg'
Command :: PATH=/usr/local/bin/:$PATH; file -b --mime '/tmp/3068f4f020f8c43d300b1e06b58b829b20161231-3455-1cldo2f.jpg'
Leitung Load (0.2ms) SELECT "leitungen".* FROM "leitungen" WHERE "leitungen"."id" = ? LIMIT ? [["id", 6], ["LIMIT", 1]]
(0.1ms) rollback transaction
No template found for Leiter::UsersController#update, rendering head :no_content
Completed 204 No Content in 81ms (ActiveRecord: 1.4ms)
出于某种原因,我能够以最奇特的方式解决这个问题。我卸载了ImageMagick,一个回形针的依赖项,突然一切正常了??我绝对无法解释为什么,但是嘿,它起作用了。。。
很明显,这不是最好的答案,但至少我现在可以继续前进。我希望在进入生产阶段时,这个问题不会再次出现。您使用的是Windows吗?@jeramaedybohol Nope,Ubuntu。
Paperclip.options[:command_path] = "/usr/local/bin/"
Started PUT "/leiter/edit" for 127.0.0.1 at 2016-12-31 18:33:19 +0000
ActiveRecord::SchemaMigration Load (0.1ms) SELECT "schema_migrations".* FROM "schema_migrations"
Processing by Leiter::UsersController#update as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"RjjDgMQESgZ/9DVXTWoTvJDitAmYXqfMyVJJyKpXDsp3hE0dejJ6erMlV+wsFEH9bFlz7ZsvBlgPO63o8PkpYw==", "user"=>{"first_name"=>"Admin", "last_name"=>"Admin", "pfadi_name"=>"Admin", "email"=>"admin@application.com", "leitung_id"=>"6", "role"=>"Admin", "avatar"=>#<ActionDispatch::Http::UploadedFile:0x00000003671238 @tempfile=#<Tempfile:/tmp/RackMultipart20161231-3455-mekx7p.jpg>, @original_filename="nobody_m.original.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"user[avatar]\"; filename=\"nobody_m.original.jpg\"\r\nContent-Type: image/jpeg\r\n">}, "commit"=>"Speichern"}
User Load (0.2ms) SELECT "users".* FROM "users" WHERE "users"."id" = ? LIMIT ? [["id", 1], ["LIMIT", 1]]
(0.1ms) begin transaction
Command :: PATH=/usr/local/bin/:$PATH; file -b --mime '/tmp/3068f4f020f8c43d300b1e06b58b829b20161231-3455-1vvcs8q.jpg'
Command :: PATH=/usr/local/bin/:$PATH; file -b --mime '/tmp/3068f4f020f8c43d300b1e06b58b829b20161231-3455-1cldo2f.jpg'
Leitung Load (0.2ms) SELECT "leitungen".* FROM "leitungen" WHERE "leitungen"."id" = ? LIMIT ? [["id", 6], ["LIMIT", 1]]
(0.1ms) rollback transaction
No template found for Leiter::UsersController#update, rendering head :no_content
Completed 204 No Content in 81ms (ActiveRecord: 1.4ms)
class User < ApplicationRecord
has_secure_password
has_attached_file :avatar, styles: { medium: "300x300>", thumb: "100x100>" }, default_url: "/images/:style/missing.png"
validates_attachment_content_type :avatar, :content_type => ["avatar/jpg", "avatar/jpeg", "avatar/png", "avatar/gif"]
belongs_to :leitung
def admin?
self.role == "Admin"
end
def al?
self.role == "Al"
end
end
class Leiter::UsersController < ApplicationController
def new
@newuser = User.new
end
def edit
@user = User.find(session[:user_id])
end
def update
@user = User.find(session[:user_id])
if @user.update_attributes(user_params) then
redirect_to '/leiter'
end
end
def create
@user = User.new(user_params)
if @user.save
redirect_to '/leiter'
else
redirect_to '/'
end
end
private
def user_params
params.require(:user).permit(:first_name, :last_name, :pfadi_name, :email, :password, :password_confirmation, :leitung_id, :role, :avatar)
end
end
<%= simple_form_for @user, url: {action: "edit"}, html: { method: :put } do |f| %>
<%= f.text_field :first_name, :placeholder => "First name" %><br>
<%= f.text_field :last_name, :placeholder => "Last name" %><br>
<%= f.text_field :pfadi_name, :placeholder => "Pfadi name" %><br>
<%= f.email_field :email, :placeholder => "Email" %><br>
<%= f.association :leitung, :placeholder => "Leitung" %><br>
<%= f.text_field :role, :placeholder => "Rolle" %><br>
<%= f.input :avatar, as: :file %>
<%= f.submit "Speichern", class: "btn-submit" %>
<% end %>
gem 'rails', '~> 5.0.0', '>= 5.0.0.1'
gem "paperclip", "~> 5.0.0"
ruby 2.3.1p112 (2016-04-26 revision 54768) [x86_64-linux]