2

これを解決するためにしばらく時間を費やしましたが、このエラーを修正するためのオプションが不足しています。M Hartl の RoR チュートリアルから Ch 8 (Sign In/Out) に到達しました。これと同様の質問があり ( Undefined method `remember_token=' 'find_by_remember_token' - 第 8 章 Ruby on Rails チュートリアル)、そこにあるすべての回答を試しましたが、役に立ちませんでした。

メソッド remember_token は、私の user.rb ファイルで定義されています。

class User < ActiveRecord::Base

before_save { self.email = email.downcase }
before_create :create_remember_token
has_secure_password
validates :name, 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, length: { minimum: 4 }
validates :password_confirmation, presence: true

def User.new_remember_token
    SecureRandom.urlsafe_base64
end


def User.encrypt(token)
    Digest::SHA1.hexdigest(token.to_s)
end 

private

    def create_remember_token
        self.remember_token = User.encrypt (User.new_remember_token)
    end

    end

私のユーザー コントローラ:

  class UsersController < ApplicationController

  def show
    @user = User.find(params[:id])
  end

  def new
    @user = User.new
  end

  def create
    @user = User.new(user_params)  # not the final implementation
    if @user.save
        # Handle a successful save.
      sign_in @user
      flash[:success] = "Welcome to Story Escape!"
      redirect_to @user
    else
        render 'new'
    end
  end

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

私のセッションコントローラー:

  class SessionsController < ApplicationController

  def new
  end


  def create
    user = User.find_by(email: params[:session][:email].downcase)
    if user && user.authenticate(params[:session][:password])
        sign_in user
        redirect_to user
    else
    flash.now[:error] = "Invalid email/password combination"
    render 'new'
  end

  def destroy
  end
    end
    end

そして、私の sessions_helper.rb:

module SessionsHelper

    def sign_in(user)
        remember_token = User.new_remember_token
        cookies.permanent[:remember_token] = remember_token
        user.update_attribute(:remember_token, User.encrypt(remember_token))
        self.current_user = user                        
    end

    def signed_in?
        !current_user.nil?
    end

    def current_user=(user)
        @current_user = user
    end

    def current_user
        @current_user ||= User.find_by(remember_token: remember_token)
    end

end

私は Ruby と Rails (および一般的なコーディング) に慣れていないので、手がかりがあれば非常に役立ちます。

4

2 に答える 2

3

私の場合、バグは追加しないというばかげた間違いでした:

remember_token = User.encrypt(cookies[:remember_token])

ここで、sessions_helper.rb ファイルで current_user を定義しました。

于 2013-10-02T04:47:41.453 に答える
1

remember_tokenモデルに属性を追加する移行を生成 (または適用) するのを忘れたようですUser

rails generate migration add_remember_token_to_users remember_token:string
rake db:migrate
rake db:test:prepare
于 2013-09-28T22:28:36.397 に答える