0

簡単な認証・登録のRubyアプリを作ろうとしています。暗号化に BCrypt gem を使用していますが、いくつかの問題が発生しています。送信ボタンを押すとスローされます

undefined method `password_salt=' for #<User:0x007f93c36bc570>

わかりましたので、このコードはモデルからコントローラーに配置する必要があることを赤くしましたが、それは私にこれを与えました

undefined local variable or method `encrypt_password' for #<User:0x007f93c5f35f10>

rake db:migrate とアプリの再起動も git repo を試しました: https://github.com/pumpurs/auth

(コードが話している)

def encrypt_password
if password.present?
  self.password_salt = BCrypt::Engine.generate_salt
  self.password_hash = BCrypt::Engine.hash_secret(password, password_salt)
end
end

コントローラ:

class UsersController < ApplicationController
  def new
  @user = User.new
end
def create
@user = User.new(params[:user].permit(:password, :email, :password_confirmation))
  if @user.save
  redirect_to root_url, :notice => "Signed up!"
else
  render "new"
end
  end

  private

  def user_params
params.require(:user).permit(:password, :email, :password_confirmation)
  end
end

モデルファイル:

class User < ActiveRecord::Base
  attr_accessor :password, :salt
  before_save :encrypt_password
  validates_confirmation_of :password
  validates_presence_of :password, :on => :create 
  validates_presence_of :email
  validates_uniqueness_of :email
   def encrypt_password
if password.present?
  self.password_salt = BCrypt::Engine.generate_salt
  self.password_hash = BCrypt::Engine.hash_secret(password, password_salt)
end
  end
end
4

1 に答える 1

1

追加

 attr_accessor :password_salt

モデルで?

Deviseや別の認証ジェムを使用しないのはなぜですか?

于 2013-09-22T20:48:41.420 に答える