0

我目前正在开发一个快速的小 sinatra 应用程序,并且我已经很容易地克服了身份验证。但是,我一生都无法更改密码才能工作。我将下面的代码与 Datamapper 一起使用,虽然它到达了重定向,但密码并没有改变。

user = User.first(:token => session[:user])
if params[:newpassword] == params[:newpasswordconfirm]
    if BCrypt::Engine.hash_secret(params[:oldpassword], user.salt) == user.password_hash
        user.password_hash = BCrypt::Engine.hash_secret(params[:newpassword], user.salt)
        user.save
        redirect '/'

我也试过

user = User.first(:token => session[:user])
if params[:newpassword] == params[:newpasswordconfirm]
    if BCrypt::Engine.hash_secret(params[:oldpassword], user.salt) == user.password_hash
        user.update(:password_hash = BCrypt::Engine.hash_secret(params[:newpassword], user.salt)
        redirect '/'

但是,这也无法更新该值。不确定我做错了什么。

class User 
include DataMapper::Resource

attr_accessor :password, :password_confirmation

property :id, Serial
property :username, String, :required => true, :unique => true
property :password_hash, Text  
property :salt, Text
property :token, String

validates_presence_of           :password
validates_confirmation_of       :password
validates_length_of             :password, :min => 6
end
4

0 回答 0