ruby-on-rails – ActiveAdmin – 在不更改密码的情况下编辑设计用户

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – ActiveAdmin – 在不更改密码的情况下编辑设计用户前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试着这样做.不幸的是我有覆盖更新的问题,我不知道如何正确地做到这一点.我在另一个地方这样做的方式是:
  1. if params[:user][:password].blank?
  2. params[:user].delete("password")
  3. params[:user].delete("password_confirmation")
  4. end
  5. # ...
  6. user.save!

所以我试图覆盖更新

  1. def update
  2. if params[:user][:password].blank?
  3. params[:user].delete("password")
  4. params[:user].delete("password_confirmation")
  5. end
  6. super
  7. end

但它不起作用.我仍然得到密码输入附近不能空白.如何实现预期的行为?

解决方法

我接受@anonymousxxx的答案并添加以下内容

如果您正在使用rails admin,则可以覆盖控制器“User”,如下所示:

  1. #app/admin/user.rb
  2. controller do
  3. def update
  4. if params[:user][:password].blank? && params[:user][:password_confirmation].blank?
  5. params[:user].delete("password")
  6. params[:user].delete("password_confirmation")
  7. end
  8. super
  9. end
  10. end

您还应注意,如果您具有用户模型验证,请指定何时应用此类验证,例如:

  1. validates :name,:email,presence: true
  2. validates :password,:password_confirmation,presence: true,on: :create
  3. validates :password,confirmation: true

这使我只有在创建新用户并更新而不更改其密码时才验证密码存在.

我希望这是有帮助的.

猜你在找的Ruby相关文章