Rails NoMethodError:未定义的方法`password_digest =

时间:2018-01-07 16:04:17

标签: ruby-on-rails bcrypt

我是rails的新手,并且已经看到了我的问题的所有可能的答案,因为其他开发人员经常会这样,但我无法解决它。请看看。

当我尝试从控制台添加数据时,我收到此错误

User.create(name: "Michael Hartl", email: "mhartl@example.com", phone: "0123456789", password: "foobar", password_confirmation: "foobar")

错误显示

undefined method `password_digest=' for #<User:0x0000000375c788>
Did you mean?  password=

控制器

 def create
    @candidate = User.new(user_params)
    if @candidate.save
      flash[:notice] = "New Candidate Added Successfully"
      redirect_to(users_path)
    else
      render('new')
    end
  end

  private

    def user_params
      #Whitelisting for strng parameters
      params.require(:user).permit(:name, :email, :password, :password_confirmation, :qualification, :college, :stream, :phone)
    end

迁移:

class CreateUsers < ActiveRecord::Migration[5.1]
  def change
    create_table :users do |t|
      t.string :name, null: false
      t.boolean :admin_user, default: false
      t.string :email, null: false
      t.string :password_digest, null: false
      t.string :qualification
      t.string :college
      t.string :stream
      t.string :phone
      t.timestamps
    end
  end
end

模型

require 'bcrypt'
class User < ApplicationRecord
    include BCrypt
    has_many :results, dependent: :destroy
    has_many :exams, through: :results
    accepts_nested_attributes_for :results

    VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i

    before_save { self.email = email.downcase }

    has_secure_password

    validates :email, presence: true
    validates :email, presence: true, length: { maximum: 255 },format: { with: VALID_EMAIL_REGEX },uniqueness: { case_sensitive: false }
    validates :password, presence: true, length: { minimum: 6 }
    validates_confirmation_of :password
    validates_presence_of :password_confirmation
    validates :name, presence: true
    validates :phone, numericality: {only_integer: true}, length: {is: 10 , message: "length should be 10"} 

    scope :visible, lambda { where(:visible => true) }
    scope :invisible, lambda { where(:visible => false) }
    scope :sorted, lambda { order("id ASC") }
    scope :newest_first, lambda { order("created_at DESC") }
    scope :search, lambda {|query| where(["name LIKE ?", "%#{query}%"]) }


end

3 个答案:

答案 0 :(得分:1)

您是否已查看此https://github.com/plataformatec/devise/issues/1845

根据问题中的描述,您正在使用ActiveModel的has_secure_password和Devise。你不能混淆两者。

可能从用户模型中移除has_secure_password将解决您的问题。

答案 1 :(得分:1)

代码完全正常,

很少有服务器重启,并且不知道如何重新启动我的代码编辑器(Visual Studio Code)对我有用。

我正在离开这个问题,因为我经历了几个stackoverflow线程后达​​到了这个代码。

注意:对于像我这样的新手,请看看如何从控制台插入数据库时​​检查错误,这有很大帮助。同义的例子是:

rails c

user = User.new ( ... . . . . .. )
user.save
user.errors

谢谢你

答案 2 :(得分:0)

这也发生在我身上,我发现有时 vscode 实际上并没有终止正在运行的进程。您将需要从终端杀死 rails。 使用 ps aux | grep rails 找出正在运行的进程并使用 kill -9 [rails-pid] 停止该进程。 在您的下一次尝试中,一切都应该正常工作。 这 answer 帮助了我。