状況
チュートリアル9.1が終わった状態。
画面のLog outリンクをクリックするとエラーが出る。
チュートリアル通りに進めてきましたが、どこが間違っているのか分からずつまずいてます。
対象ソース
app/models/user.rb
ruby
1class User < ApplicationRecord 2 attr_accessor :remember_token 3 before_save { email.downcase! } 4 validates :name, presence: true, length: { maximum: 50 } 5 VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(.[a-z\d\-]+)*.[a-z]+\z/i 6 validates :email, presence: true, length: { maximum: 255 }, 7 format: { with: VALID_EMAIL_REGEX }, 8 uniqueness: { case_sensitive: false } 9 has_secure_password 10 validates :password, presence: true, length: { minimum: 6 } 11 12 class << self 13 14 # 渡された文字列のハッシュ値を返す 15 def User.digest(string) 16 cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : 17 BCrypt::Engine.cost 18 BCrypt::Password.create(string, cost: cost) 19 end 20 21 # ランダムなトークンを返す 22 def User.new_token 23 SecureRandom.urlsafe_base64 24 end 25 26 # 永続セッションのためにユーザーをデータベースに記憶する 27 def remember 28 self.remember_token = User.new_token 29 self.update_attribute(:remember_digest, User.digest(remember_token)) 30 end 31 32 # 渡されたトークンがダイジェストと一致したらtrueを返す 33 def authenticated?(remember_token) 34 return false if remember_digest.nil? 35 BCrypt::Password.new(self.remember_digest).is_password?(remember_token) 36 end 37 38 # ユーザーのログイン情報を破棄する 39 def forget 40 self.update_attribute(:remember_digest, nil) 41 end 42 end 43end 44
app/controllers/users_controller.rb
ruby
1class UsersController < ApplicationController 2 3 def show 4 @user = User.find(params[:id]) 5 end 6 7 def new 8 @user = User.new 9 end 10 11 def create 12 @user = User.new(user_params) 13 if @user.save 14 log_in @user 15 flash[:success] = "Welcome to the Sample App!" 16 redirect_to @user 17 else 18 render 'new' 19 end 20 end 21 22 private 23 def user_params 24 params.require(:user).permit(:name, :email, :password, 25 :password_confirmation) 26 end 27end 28
app/helpers/sessions_helper.rb
ruby
1module SessionsHelper 2 3 # 渡されたユーザーでログインする 4 def log_in(user) 5 session[:user_id] = user.id 6 end 7 8 # ユーザーのセッションを永続的にする 9 def remember(user) 10 user.remember 11 cookies.permanent.signed[:user_id] = user.id 12 cookies.permanent[:remember_token] = user.remember_token 13 end 14 15 # 記憶トークンcookieに対応するユーザーを返す 16 def current_user 17 if (user_id = session[:user_id]) 18 @current_user ||= User.find_by(id: user_id) 19 elsif (user_id = cookies.signed[:user_id]) 20 user = User.find_by(id: user_id) 21 if user && user.authenticated?(cookies[:remember_token]) 22 log_in user 23 @current_user = user 24 end 25 end 26 end 27 28 # ユーザーがログインしていればtrue、その他ならfalseを返す 29 def logged_in? 30 !current_user.nil? 31 end 32 33 # 永続的セッションを破棄する 34 def forget(user) 35 user.forget 36 cookies.delete(:user_id) 37 cookies.delete(:remember_token) 38 end 39 40 # 現在のユーザーをログアウトする 41 def log_out 42 forget(current_user) 43 session.delete(:user_id) 44 @current_user = nil 45 end 46end
app/controllers/sessions_controller.rb
ruby
1class SessionsController < ApplicationController 2 def new 3 end 4 5 def create 6 user = User.find_by(email: params[:session][:email].downcase) 7 if user && user.authenticate(params[:session][:password]) 8 log_in user 9 remember user 10 redirect_to user 11 else 12 flash.now[:danger] = 'Invalid email/password combination' 13 render 'new' 14 end 15 end 16 17 def destroy 18 log_out if logged_in? 19 redirect_to root_url 20 end 21end
ご指摘いただけますと幸いです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/05/05 09:10