ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
エラー内容
Laravel\Socialite\Two\InvalidStateException
No message
in vendor/laravel/socialite/src/Two/AbstractProvider.php:nnn
at AbstractProvider->getUser()
Google / Facebook / GitHub 等の OAuth 認証のコールバック処理で発生します。OAuth 2.0 の state パラメータ検証に失敗している状態です。
原因: OAuth state パラメータ
OAuth 2.0 では CSRF 対策として state パラメータを使います:
- クライアント → 認可サーバへリダイレクトする際、ランダムな
stateをセッションに保存し、URL にも付与 - 認可サーバ → コールバックでクライアントに戻すとき、同じ
stateを返す - クライアント → セッションの state と URL の state が一致するか確認 (不一致なら CSRF 攻撃の可能性)
このマッチングが失敗するのが InvalidStateException。原因は:
- セッションが切れた(コールバックまで時間が空きすぎ)
- セッション Cookie がコールバック先に届かない(ドメイン違い・SameSite 設定)
- 複数サーバ環境でセッションが共有されていない(ロードバランサ)
- ブラウザのプライバシー設定でサードパーティ Cookie ブロック
- キャッシュされた古いコールバック URL を再送信
対処1: stateless() で state チェックを無効化
API モードや SPA など、セッションを使わない場合は state チェック自体をオフに:
// app/Http/Controllers/Auth/LoginController.php
use Laravel\Socialite\Facades\Socialite;
public function redirectToProvider() {
return Socialite::driver('google')->stateless()->redirect();
}
public function handleProviderCallback() {
$user = Socialite::driver('google')->stateless()->user();
// ... ユーザ作成 or ログイン
}
注意: stateless にすると CSRF 対策が無くなるので、別の方法(JWT, nonce 検証等)で守る必要があります。
対処2: セッションドライバ設定の確認
.env でセッションドライバを確認:
# 単一サーバなら file / database / redis いずれも OK
SESSION_DRIVER=file
# 複数サーバ環境(ロードバランサ配下)では shared なドライバ必須
SESSION_DRIVER=redis
# または
SESSION_DRIVER=database
# Cookie ドメインを正しく
SESSION_DOMAIN=.example.com # サブドメイン跨ぎなら先頭ドット
# HTTPS 環境では Secure 必須
SESSION_SECURE_COOKIE=true
# OAuth コールバック後に新セッションでなく既存セッションを引き継ぐ
SESSION_LIFETIME=120
対処3: コールバック URL の整合性
Developer Console(Google / Facebook 等)に登録したコールバック URL と、アプリの実 URL が一致しているか:
| 登録 URL | 実際の URL | 結果 |
|---|---|---|
| https://app.example.com/auth/google/callback | https://app.example.com/auth/google/callback | ○ |
| https://app.example.com/auth/google/callback | https://www.app.example.com/auth/google/callback | × (サブドメイン違い) |
| https://app.example.com/auth/google/callback | http://app.example.com/auth/google/callback | × (プロトコル違い) |
| https://app.example.com/auth/google/callback | https://app.example.com/auth/google/callback/ | ×〜△ (末尾スラッシュ) |
対処4: SameSite Cookie の調整
外部認可サーバから戻ってくる際、SameSite=Strict だと Cookie が送られず state チェック失敗:
// config/session.php
'same_site' => 'lax', // 'strict' から 'lax' に
// または 'none' (Secure と組み合わせ必須)
対処5: HTTPS 統一
OAuth は本番では HTTPS が前提。HTTP と HTTPS が混在するとセッション Cookie が共有されずエラー:
// AppServiceProvider.php
use Illuminate\Support\Facades\URL;
public function boot() {
// 本番では強制 HTTPS
if (config('app.env') === 'production') {
URL::forceScheme('https');
}
}
対処6: 直前の処理ログを確認
public function handleProviderCallback(Request $request) {
\Log::info('OAuth Callback', [
'state_url' => $request->state,
'state_session' => session()->get('state'),
'has_code' => $request->has('code'),
'all_query' => $request->query(),
]);
try {
$user = Socialite::driver('google')->user();
} catch (\Laravel\Socialite\Two\InvalidStateException $e) {
\Log::error('InvalidState', ['e' => $e->getMessage()]);
return redirect('/login')->with('error', 'セッションが切れました');
}
// ...
}
原因の切り分けチェックリスト
- ログインからコールバックまでの時間を測る(5 分以上空くと session lifetime に引っかかる)
- ブラウザのシークレットウィンドウで試す(拡張機能の影響を除外)
- HTTP Cookie 設定を SameSite=Lax に変更
- セッションドライバを database にして DB の sessions テーブルを目視
- 別ブラウザで再試行
- HTTPS を本番では必須に
関連エラー
- Symfony\Component\HttpKernel\Exception\HttpException — ルート未定義
- Client Error: 401 Unauthorized — Developer Console の Client ID / Secret が違う
- Mismatch redirect_uri — 登録済みコールバック URL と実 URL が違う
- Tokens not yet received — リダイレクトせずに直接コールバック URL にアクセスした
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- SQLSTATE[HY000] [1045] Access denied for user 'homestead'@'localhost'
- Add [~] to fillable property to allow mass assignment on [App\~].
- PHP Parse error: syntax error, unexpected 'class' (T_CLASS), expecting identifier (T_STRING) or variable (T_VARIABLE) or '{' or '$' in ~
- Changing columns for table "~" requires Doctrine DBAL; install "doctrine/dbal"
- MethodNotAllowedHttpException No message
- Class 'Doctrine\DBAL\Driver\PDOMySql\Driver' not found
- production.ERROR: No application encryption key has been specified.
- Dotenv values containing spaces must be surrounded by quotes.
- Laravel \ Socialite \ Two \ InvalidStateException
- The page has expired due to inactivity. Please refresh and try again.
- Failed to clone https://github.com/symfony/thanks.git via https, ssh protocol
- Illegal offset type
- Cannot access protected property Illuminate\Http\Request::$...
- Emitted value instead of an instance of Error
- 画像保存時にInternal Server Error
- Failed to authenticate on SMTP server with username ...
- PostTooLargeException
- Database hosts array is empty.
- Invalid request (Unsupported SSL request)
- does not comply with psr-4 autoloading standard. Skipping.
- MySQLのSTR_TO_DATE関数を使用するとnullが返却される問題
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?