当我尝试重置密码时,我收到此错误:
PasswordResetsController中的ArgumentError #create
错误的参数数量(1表示0)
app / models / user.rb:48:in
中create_remember_token app/models/user.rb:40:in
send_password_reset app / controllers / password_resets_controller.rb:7:在'create'
class PasswordResetsController < ApplicationController
def new
end
def create
user = User.find_by_email(params[:email])
user.send_password_reset if user
redirect_to root_url
end
def edit
@user = User.find_by_password_reset_token!(params[:id])
end
def update
@user = User.find_by_password_reset_token!(params[:id])
if @user.password_reset_sent_at < 2.hours.ago
redirect_to new_password_reset_path, :alert => "Password ↵
reset has expired."
elsif @user.update_attributes(params[:user])
redirect_to root_url, :notice => "Password has been reset."
else
render :edit
end
end
end
class User < ActiveRecord::Base
attr_accessible :email, :lname, :name, :password, :password_confirmation
has_secure_password
before_save { |user| user.email = email.downcase }
before_save :create_remember_token
validates :name, presence: true, length: { maximum: 50 }
validates :lname, presence: true, length: { maximum: 50 }
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
validates :email, presence: true, format: { with: VALID_EMAIL_REGEX },
uniqueness: { case_sensitive: false }
validates :password, presence: true, :on => :create
validates :password, length: { minimum: 6 }, :allow_blank => true
validates :password_confirmation, presence: true, :on => :create
def send_password_reset
create_remember_token(:password_reset_token)
self.password_reset_sent_at = Time.zone.now
save!
UserMailer.password_reset(self).deliver
end
private
def create_remember_token
self.remember_token = SecureRandom.urlsafe_base64
end
end
有人知道为什么?
答案 0 :(得分:3)
当create_remember_token的方法定义不接受参数时,您正在调用create_remember_token(:password_reset_token)。
换句话说改变
create_remember_token(:password_reset_token)
到
create_remember_token
你的send_password_reset方法中的
答案 1 :(得分:1)
添加到before_save remember_token并更改了create_remember_token
我不知道是不是?但它的工作原理
class User < ActiveRecord::Base
attr_accessible :email, :lname, :name, :password, :password_confirmation
has_secure_password
before_save { |user| user.email = email.downcase }
before_save { create_remember_token(:remember_token) }
validates :name, presence: true, length: { maximum: 50 }
validates :lname, presence: true, length: { maximum: 50 }
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
validates :email, presence: true, format: { with: VALID_EMAIL_REGEX },
uniqueness: { case_sensitive: false }
validates :password, presence: true, :on => :create
validates :password, length: { minimum: 6 }, :allow_blank => true
validates :password_confirmation, presence: true, :on => :create
def send_password_reset
create_remember_token(:password_reset_token)
self.password_reset_sent_at = Time.zone.now
save!
UserMailer.password_reset(self).deliver
end
def create_remember_token(column)
begin
self[column] = SecureRandom.urlsafe_base64
end while User.exists?(column => self[column])
end
end