ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
エラー画面
419 | Page Expired
The page has expired due to inactivity.
Please refresh and try again.
Laravel のCSRF (Cross-Site Request Forgery) 保護機構が、リクエストの _token とサーバ側セッションの _token が一致しないと判断したときに表示します。HTTP ステータスは 419 (Authentication Timeout)。
原因と対処の早見表
| 原因 | 確認 | 対処 |
|---|---|---|
フォームに @csrf 無し | form タグ内を確認 | @csrf 追加 |
| セッション失効 | 表示後の経過時間 | SESSION_LIFETIME 延長 |
| storage/framework/sessions 権限不足 | ls -la storage/framework/sessions | 権限修正 or Redis 化 |
| SESSION_DOMAIN ミス | .env の値 | ドメイン合わせる |
HTTPS 化したのに SESSION_SECURE_COOKIE 未設定 | .env / Chrome DevTools のCookies | SESSION_SECURE_COOKIE=true |
| マルチドメインで Cookie 共有失敗 | サブドメイン構成 | SESSION_DOMAIN=.example.com |
対処1: フォームに @csrf を追加
POST / PUT / PATCH / DELETE フォームには必ず @csrf を入れます:
{{-- ❌ NG: トークン無し → 419 --}}
{{-- ✅ OK --}}
{{-- @csrf の展開後 --}}
Ajax / fetch の場合
{{-- HTML に --}}
対処2: セッション寿命を延長
// config/session.php
'lifetime' => env('SESSION_LIFETIME', 120), // 分単位、デフォルト 120 分
'expire_on_close' => false, // ブラウザ閉じても保持# .env
SESSION_LIFETIME=480 # 8 時間
長時間入力フォーム(記事作成画面など)には定期的に CSRF トークンを再取得するのが本筋:
// 10 分おきにトークンをリフレッシュ
setInterval(async () => {
const res = await fetch('/csrf-token'); // 専用エンドポイント
const data = await res.json();
document.querySelector('meta[name="csrf-token"]').content = data.token;
document.querySelector('input[name="_token"]').value = data.token;
}, 600 * 1000);// routes/web.php
Route::get('/csrf-token', fn() => response()->json(['token' => csrf_token()]));
対処3: storage 権限の確認
セッションドライバが file で storage が書けないと、毎リクエスト新セッションになり即 419:
# 確認
ls -la storage/framework/sessions
# drwxr-xr-x www-data:www-data の存在を確認
# 修正
chown -R www-data:www-data storage bootstrap/cache
chmod -R 775 storage bootstrap/cache
# Laravel Sail
./vendor/bin/sail artisan storage:link
セッションドライバを Redis / DB へ
# .env
SESSION_DRIVER=redis # おすすめ(高速 + クラスタ対応)
SESSION_DRIVER=database # 代替
SESSION_DRIVER=cookie # 暗号化 Cookie に格納(容量制限あり)# DB ドライバ使用時
php artisan session:table
php artisan migrate
対処4: HTTPS / マルチドメインでの Cookie 設定
# .env
# HTTPS のみ Cookie 送信(本番では必須)
SESSION_SECURE_COOKIE=true
# サブドメイン間で Cookie 共有
SESSION_DOMAIN=.example.com
# SameSite 制御
SESSION_SAME_SITE=lax # lax / strict / none
# none を使う場合は SECURE_COOKIE=true 必須
対処5: 特定の URL を CSRF 検証から除外
外部 Webhook 受信 / 決済リダイレクト等、CSRF トークンを付けられない POST がある場合:
// app/Http/Middleware/VerifyCsrfToken.php
class VerifyCsrfToken extends Middleware
{
protected $except = [
'/webhook/stripe',
'/webhook/*',
'/payment/notify',
];
}
注意: 除外は最小限に。外部 API の署名検証などで別途守る必要があります。
トラブルシュート手順
- Chrome DevTools → Application → Cookies で
XSRF-TOKENとlaravel_sessionが存在するか - 送信時の Form Data に
_tokenが含まれているか確認 storage/logs/laravel.logに詳細エラーが出ていないかstorage/framework/sessions/直下にファイルが書かれるか(file ドライバの場合)- クリックして送信するまでの滞在時間が SESSION_LIFETIME を超えていないか
FAQ
Q: ブラウザを開きっぱなしで翌日送信したら 419
A: 期待動作です。長時間の場合は Ajax で定期的にトークン更新するか、SESSION_LIFETIME を延長してください。
Q: ログイン後すぐ 419 になる
A: SESSION_DRIVER=file + storage 権限不足のパターンが多いです。Redis / DB ドライバを推奨。
Q: SPA で 419 が出る
A: Laravel Sanctum を使う場合は config/sanctum.php の stateful ドメイン設定と、フロントの withCredentials: true を確認。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?