かんたんログイン機能をつけようとしています。
トップ画面に以下のリンクをつけ、
rails5
1<%= link_to("かんたんログイン", "/guest_login") %>
Routes.rbで以下のようにメソッドに送ります。
rails5
1get "guest_login" => "users#guest_login"
そして以下のメソッドでゲストユーザーとしてログインを試みています。
名前:GuestUser
メール:guest@example.com
パスワード:ランダム
rails5
1(users_controller.rb) 2 def guest_login 3 user = User.find_or_create_by(email: 'guest@example.com') 4 user.name = "GuestUser" 5 user.password = SecureRandom.urlsafe_base64 6 session[:user_id] = user.id 7 redirect_to("/posts/index") 8 flash[:notice] = "ゲストユーザーとしてログインしました" 9 end
しかし実際に上記のゲストユーザーがある場合はログインできるのですが、
メールアドレスを変更してしまうとログインができません。
以下のような記事を見るとfind_or_create_byは検索条件に合致するデータが存在した場合はそれを使い、
存在しない場合は新規作成するとあります。
http://maru877.hatenablog.com/entry/2017/07/07/211422
https://qiita.com/taimuzu/items/0a21738d018f475d63ae
上記のコードでは検索しかされず、新規作成をしてくれません。
どこを修正すればかんたんログイン機能になるのか、教えていただけると助かります。
参考までコントローラ全部を貼っておきます。
rails5
1(user_control.rb) 2class UsersController < ApplicationController 3 before_action :authenticate_user, {only: [:index, :show, :edit, :update]} 4 before_action :forbid_login_user, {only: [:new, :create, :login_form, :login]} 5 before_action :ensure_correct_user, {only: [:edit, :update]} 6 7 def index 8 @users = User.all 9 end 10 11 def show 12 @user = User.find_by(id: params[:id]) 13 end 14 15 def new 16 @user = User.new 17 end 18 19 def create 20 @user = User.new( 21 name: params[:name], 22 email: params[:email], 23 image_name: "default_user.jpg", 24 password: params[:password] 25 ) 26 if @user.save 27 session[:user_id] = @user.id 28 flash[:notice] = "ユーザー登録が完了しました" 29 redirect_to("/users/#{@user.id}") 30 else 31 render("users/new") 32 end 33 end 34 35 def edit 36 @user = User.find_by(id: params[:id]) 37 end 38 39 def update 40 @user = User.find_by(id: params[:id]) 41 @user.name = params[:name] 42 @user.email = params[:email] 43 44 if params[:image] 45 @user.image_name = "#{@user.id}.jpg" 46 image = params[:image] 47 File.binwrite("public/user_images/#{@user.image_name}", image.read) 48 end 49 50 if @user.save 51 flash[:notice] = "ユーザー情報を編集しました" 52 redirect_to("/users/#{@user.id}") 53 else 54 render("users/edit") 55 end 56 end 57 58 def login_form 59 end 60 61 def login 62 @user = User.find_by(email: params[:email]) 63 if @user && @user.authenticate(params[:password]) 64 session[:user_id] = @user.id 65 flash[:notice] = "ログインしました" 66 redirect_to("/posts/index") 67 else 68 @error_message = "メールアドレスまたはパスワードが間違っています" 69 @email = params[:email] 70 @password = params[:password] 71 render("users/login_form") 72 end 73 end 74 75 def guest_login 76 user = User.find_or_create_by(email: 'guest@example.com') 77 user.name = "GuestUser" 78 user.password = SecureRandom.urlsafe_base64 79 session[:user_id] = user.id 80 redirect_to("/posts/index") 81 flash[:notice] = "ゲストユーザーとしてログインしました" 82 end 83 84 def logout 85 session[:user_id] = nil 86 flash[:notice] = "ログアウトしました" 87 redirect_to("/login") 88 end 89 90 def likes 91 @user = User.find_by(id: params[:id]) 92 @likes = Like.where(user_id: @user.id) 93 end 94 95 def ensure_correct_user 96 if @current_user.id != params[:id].to_i 97 flash[:notice] = "権限がありません" 98 redirect_to("/posts/index") 99 end 100 end 101 102end 103
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2019/12/30 23:25
2019/12/31 00:02
退会済みユーザー
2019/12/31 00:09
2019/12/31 00:12
退会済みユーザー
2019/12/31 04:24