1

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

しかし、それは正しく機能せず、エラーが発生します:「未定義のメソッド `authenticate' for #」

4

1 に答える 1