質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Authentication

Authentication(認証)は正当性を認証する為の工程です。ログイン処理等で使われます。

Q&A

0回答

2068閲覧

Laravelでログアウト時にSession store not set on requestエラーになる

gasa

総合スコア4

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Authentication

Authentication(認証)は正当性を認証する為の工程です。ログイン処理等で使われます。

0グッド

0クリップ

投稿2021/05/08 10:42

#環境
プログラミング初学者です。
理解が足りない部分だらけですが、よろしくお願いします。

php 7系
Laravel8系
OSはwindowsでdocker上で開発しています。
認証はLaravel Breezeを使っています。

#困っていること
ログアウトリンクを作り、アクセスすると、ブラウザで**Session store not set on request.**というエラーが出ます。
その後、ページをリロードするとログイン画面にリダイレクトされ。ログアウト自体は出来ます。

エラー画面のstack traceでは、Illuminate/Illuminate/Http/Request.phpのsession()メソッドに引っかかっているみたいなことが表示されています。

Requestphp

1 public function session() 2 3 { 4 5 if (! $this->hasSession()) { 6 7 throw new RuntimeException('Session store not set on request.'); //このエラー文が出てるみたいです  8 9 } 10 11 12 13 return $this->session; 14 15 }

また、AuthenticatedSessionControllerのdestroy()メソッド(ログアウト処理をするメソッド)のsession()->invalidate()が問題みたいな表示があります。

AuthenticatedSessionController

1 public function destroy(Request $request) 2 3 { 4 5 Auth::logout(); 6 7 8 9 $request->session()->invalidate(); //この部分 10 11 12 13 $request->session()->regenerateToken(); 14 15 16 17 return redirect('/'); 18 19 }

実際に$request->session()->invalidate();をコメントにすると問題なくログアウトできました。

その他、ログインした状態でAuth::id()Auth::user()を実行するとnullが返ってきます。
これも何か関係があるのではないかと思いますが、原因がさっぱりわかりません。

sessionドライバーはdatabaseに設定しています。
sessionsテーブルのuser_idカラムは、ログイン後にユーザーidが入り、ログアウト後はnullになるので特に問題ないように見えます。

開発自体は終盤に入ってきたので、ログアウト出来ないことで挫折するのは避けたいです。
どうかお力添えください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/05/08 14:26

「laravel breeze "Session store not set on request."」でネット検索するだけでも、手掛かりが見つかるのですが、見てます?
gasa

2021/05/08 14:54

ご意見ありがとうございます。 ご指摘のキーワードで何度も検索しましたところ、kernel.phpにミドルウェアを追加するというような内容がほとんどでした。 実際にそれらを試しましたが、変わりがありませんでした。 たった今、api.phpに定義したルーティングをweb.phpに移しましたら、auth::id()は機能するようになりました。 しかし、やはりログアウトは出来ません。 恥ずかしながら最近vue.jsをかじり始めた関係でちょっとapi.phpを触ってみた程度なので、何が起きているかよくわかっていません。 何かご指摘がありましたら、ぜひ教授ください。 つたない説明で申し訳ありません。
退会済みユーザー

退会済みユーザー

2021/05/08 14:57

何かを見て、どう対策をやったか、その結果どうなったのか、それらを丁寧に質問文に反映してください。無駄なやり取りはしたくないし、すでに試したことを助言されてもいやでしょ?
gasa

2021/05/08 15:23

基本的にこちらのページを参考にしました。 https://stackoverflow.com/questions/34449770/laravel-session-store-not-set-on-request まずkernel.phpのprotected $middlewareGroupsのapiに下記のようにミドルウェアを追加しました。 'api' => [     \App\Http\Middleware\EncryptCookies::class,               //追加  \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, //追加  \Illuminate\Session\Middleware\StartSession::class, //追加 'throttle:api', \Illuminate\Routing\Middleware\SubstituteBindings::class, ], しかし変化ありませんでした。 次に、kernel.phpのprotected $middlewareに下記のように追加しました。 protected $middleware = [ \App\Http\Middleware\EncryptCookies::class, //追加 \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, //追加 \Illuminate\Session\Middleware\StartSession::class, //追加 // \App\Http\Middleware\TrustHosts::class, \App\Http\Middleware\TrustProxies::class, \Fruitcake\Cors\HandleCors::class, \App\Http\Middleware\PreventRequestsDuringMaintenance::class, \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class, \App\Http\Middleware\TrimStrings::class, \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class, ]; すると、ログアウトリンクを踏んだ時に、419エラーに変わりました。 そこで、protected $middlewareに\App\Http\Middleware\VerifyCsrfToken::classを追加してみましたが、419エラーのままでした。 その後、\App\Http\Middleware\VerifyCsrfToken::classを消して、\Illuminate\View\Middleware\ShareErrorsFromSession::classを追加してみましたが、ログインの際にも419エラーが出るようになりました。 ログアウト処理のルーティングもコントローラも初期の状態から触っていないので、何が起きてるのかさっぱりわかりません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問