在Rails应用程序中为Devise视图/模型添加其他字段和验证

时间:2010-09-11 22:24:25

标签: ruby-on-rails validation devise

我使用以下内容生成了默认的devise视图:

rails generate devise:views

然后我在username表单中添加了views/devise/registrations/new.html.erb字段。

目前,只会进行emailpassword验证。如何验证username字段的存在性和唯一性?我是否需要向User模型添加内容?

4 个答案:

答案 0 :(得分:19)

我使用了其他答案中提到的两个教程Railscast #210Devise Wiki。但是,据我所知,他们没有明确说明如何验证用户名字段的存在和/或唯一性。

如果您通过简单迁移添加了用户名 -

rails generate migration addUsernameToUser username:string

然后设计不会对该字段做任何特殊操作,因此您需要在用户模型中自行添加对验证和唯一性的检查。

class User < ActiveRecord::Base
...
  validates_presence_of :username
  validates_uniqueness_of :username

但是,如果查看RailsCast#209,则会有一个用于创建User模型的迁移示例。

class DeviseCreateUsers < ActiveRecord::Migration  
  def self.up  
    create_table(:users) do |t|  
      t.database_authenticatable :null => false  
      # t.confirmable  
      t.recoverable  
      t.rememberable  
      t.trackable  
      # t.lockable :lock_strategy => :failed_attempts, :unlock_strategy => :both  

      t.timestamps  
    end  

    add_index :users, :email,                :unique => true  
    # add_index :users, :confirmation_token,   :unique => true  
    add_index :users, :reset_password_token, :unique => true  
    # add_index :users, :unlock_token,         :unique => true  
  end  

  def self.down  
    drop_table :users  
  end  
end  

请注意,用户电子邮件被定义为唯一的。也许如果使用相同的语法添加用户名,那么设计魔术会照顾存在和唯一性。

答案 1 :(得分:14)

Rails 4和强参数

除此之外,我必须使用以下方式生成视图:

$ rails g devise:views

然后在devise.rb添加:

config.scoped_views = true

最后为sign_up配置允许的参数,如下所示:

class ApplicationController < ActionController::Base

  before_filter :configure_permitted_parameters, if: :devise_controller?

  protected

    def configure_permitted_parameters
      devise_parameter_sanitizer.for(:sign_up) do |u|
        u.permit :username, :email, :password, :password_confirmation
      end
    end
end

This is described in Devise Doc

此外,我对username的验证如下:

validates :username, presence: true
validates :username, uniqueness: true, if: -> { self.username.present? }

我使用两行,所以如果username为空,我只会收到一个错误。

答案 2 :(得分:0)

如果有人想知道如何获取登录名以检查用户名是否为空 或确保用户不能使用相同的用户名。我花了很多 几个小时试图弄清楚这一点,在ned中,我只需要添加:

validates_uniqueness_of :username, case_sensitive: false
validates_presence_of :username

到您的app / models /

中的user.rb文件

这是文档... https://api.rubyonrails.org/classes/ActiveRecord/Validations/ClassMethods.html

这现在引发我需要的错误。 我感觉像个白痴,因为我首先找到了uniquness_of,然后又回去花了数小时试图弄清楚如何检查空白字段,然后发现它和另一个字段在同一文档中。我是菜鸟。 >

现在要弄清楚如何更改错误消息,因为它们不在devise.en.yml中

答案 3 :(得分:-2)

只需在用户模型和Devise wiki上添加用户名字段: http://github.com/plataformatec/devise/wiki/Sign-in-using-login-or-mail

希望它有所帮助。