我想在我的rails应用程序中添加'更改密码'功能,我从这里开始学习(207.44.138.58/~rorexper/viewtopic.php?t=690&highlight=&sid=16f7417dcbb3cb8960912c8134351fd9)
在我的视图页面中,我添加: -
= form_tag :action => 'update' do
- flash.each do |key, value|
%div.TxtRed{:class => "flash #{key}"}= value
%p
%label Current password
%br
= password_field_tag "user[current_password]", nil
%p
%label New password
%br
= password_field_tag "user[password]", nil
%p
%label Confirm password
%br
= password_field_tag "user[password_confirmation]", nil
%P
= button_tag "Save", :class => "btn-custom ML10", :type => :submit
在控制器中: -
def update
return unless request.post?
@user = Refinery::User.find_by_id(current_user.id)
if current_user = Refinery::User.authenticate(@user.username, params[:user][:current_password])
if (params[:user][:password] == params[:user][:password_confirmation])
current_user.encrypted_password = crypted_password(params[:user] [:password] ,current_user.salt)
flash[:notice] = current_user.save ?"Password changed" :"Password not changed"
redirect_to my_page_path
else
flash[:notice] = "Password mismatch"
@current_password = params[:current_password]
end
else
flash[:notice] = "Wrong password"
end
end
def crypted_password(password, salt)
string_to_hash = password + "nyros" + salt
Digest::SHA1.hexdigest(string_to_hash)
end
但它无法正常工作并出错: “未定义的方法`认证'用于#”
答案 0 :(得分:0)
如果调用它的对象为nil,则authenticate方法将引发异常。换句话说,当find_by
找不到匹配的用户时。
测试@user在if
结构的条件下不是nil,而不是在if条件中调用authenticate方法。所以改变:
@user = Refinery::User.find_by_id(current_user.id)
if !@user.nil?
current_user = Refinery::User.authenticate(@user.username, params[:user][:current_password])
.
.
.
到
@user = Refinery::User.find_by_id(current_user.id)
current_user = Refinery::User.authenticate(@user.username, params[:user][:current_password])