ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
Request の値を変更する 3 つの方法
① merge() - 既存値はそのまま、追加・上書き
use Illuminate\Http\Request;
public function store(Request $request)
{
// 元の入力に user_id を追加
$request->merge([
'user_id' => auth()->id(),
'created_at' => now(),
]);
// 既存キーがあれば上書きされる
$request->merge(['status' => 'pending']);
// この時点で $request->input('user_id') が取れる
User::create($request->all());
}
② replace() - 全部置き換え
public function store(Request $request)
{
// 元の入力を完全に上書き
$request->replace([
'name' => 'NewName',
'email' => 'new@example.com',
]);
// この時点で他のフィールドはすべて消える
}
③ 個別キーの設定
// 単一キーの追加・変更
$request->offsetSet('key', 'value');
// 配列アクセスで
$request['key'] = 'value';
// オブジェクトのように代入 (Laravel 8+)
$request->key = 'value';
Header の変更
// 追加・上書き
$request->headers->set('X-Custom-Header', 'value');
// 削除
$request->headers->remove('X-Custom-Header');
// 取得
$value = $request->header('X-Custom-Header');
Query Parameter の変更
// すべての query を取得
$queries = $request->query();
// 単一 query 変更
$request->query->set('page', 2);
// 全部置き換え
$request->query->replace(['page' => 1, 'limit' => 20]);
ミドルウェアで前処理する(推奨)
コントローラ内で $request を変更するより、ミドルウェアで前処理する方が責務分離できます:
// app/Http/Middleware/AddUserToRequest.php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
class AddUserToRequest
{
public function handle(Request $request, Closure $next)
{
if (auth()->check()) {
$request->merge([
'user_id' => auth()->id(),
'user_name' => auth()->user()->name,
]);
}
return $next($request);
}
}
// app/Http/Kernel.php
protected $middlewareGroups = [
'web' => [
// 既存のミドルウェア...
\App\Http\Middleware\AddUserToRequest::class,
],
];
// または特定ルートで
Route::post('/posts', [PostController::class, 'store'])
->middleware(AddUserToRequest::class);
FormRequest で前処理する
バリデーション前後で値を加工:
// app/Http/Requests/StorePostRequest.php
class StorePostRequest extends FormRequest
{
// バリデーション前に値を加工
protected function prepareForValidation()
{
$this->merge([
'slug' => Str::slug($this->title),
'user_id' => auth()->id(),
]);
}
public function rules()
{
return [
'title' => 'required|max:100',
'slug' => 'required|unique:posts,slug',
'user_id' => 'required|exists:users,id',
];
}
// バリデーション通過後の加工
protected function passedValidation()
{
$this->merge([
'content_html' => Str::markdown($this->content),
]);
}
}
注意点
1. all() / input() のキャッシュ
Laravel は $request->all() の結果を内部的にキャッシュすることがあります。merge 後は再取得:
$data = $request->all();
$request->merge(['foo' => 'bar']);
$data2 = $request->all(); // 再取得すると foo が含まれる
2. validated() は変更前の値を見る場合がある
public function rules() { return ['name' => 'required']; }
// バリデーション後に merge しても validated() には反映されない
$request->validate($rules);
$request->merge(['name' => 'New']);
$validated = $request->validated(); // 元の値のまま
// 反映したい場合は prepareForValidation で merge
3. JSON リクエストでは all() に注意
JSON ボディと query 両方ある場合の挙動を確認してください:
// POST /users?source=admin
// Body: {"name": "Alice"}
$request->all(); // ['source' => 'admin', 'name' => 'Alice']
$request->query(); // ['source' => 'admin']
$request->json()->all(); // ['name' => 'Alice']
$request->input('name'); // 'Alice' (両方から検索)
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- インストールと設定
- クイックスタート & チュートリアル(初心者向け)
- クイックスタート & チュートリアル(中級者向け)
- ルーティング
- Bladeテンプレート(ビュー/レイアウト)
- コントローラー
- マイグレーションとテーブル定義
- データベースの設定
- Eloquentモデル (ORM)
- SQLとクエリビルダー
- バリデーション
- .envファイルの設定値へのアクセス
- 動作環境による分岐処理
- configフォルダ配下の設定値へのアクセス
- assetヘルパーを利用したpublicフォルダへのアクセス
- storageフォルダへのアクセス
- アプリケーション名の変更
- メンテナンス
- ログイン画面(認証システム)の作成
- ログインの必須化
- ログインユーザー情報の取得
- ルートの認証化
- 本番サーバーへのデプロイ方法
- 多言語化
- csrf_field
- ファイルのダウンロード
- CSVのアップロードおよび読み込み(maatwebsite/excel)
- ページタイトルの設定
- コマンド一覧
- エラー一覧
- SQLの実行ログ出力方法
- キャッシュのクリア
- Selectの結果の最初もしくは最後に任意の値を追加する方法
- ajaxでPOST通信する際の注意点
- ソーシャルログインの実装
- セッション情報の確認
- ログイン、ユーザー登録、パスワードリセット後のリダイレクト先の変更方法
- redirectやreturn viewにメッセージを付与する方法
- クッキー(cookie)の設定と取得
- クラスの再読み込み
- csrfの有効時間を変更する方法
- ViewComposerを用いてviewに共通の値を付与する方法
- View::shareを用いて共通の値を各ビューに渡す方法
- ミドルウェアを用いた処理の共通化
- Middleware内でAuth::check()などを使用する方法
- Controller以外でリダイレクトする方法
- セッションの値の取得/保存/更新/削除
- $requestの値を変更する方法
- 常時SSL化
- ページング(ページネーション)をする方法
- vue.jsとの連携
- Vue.jsと連携するSPA実行環境構築
- .envの値をvue.jsで参照する方法
- vue.jsを本番環境にリリースする方法
- could not find driver(Windows, MySQL編)
人気ページ
- 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
コメントを削除してもよろしいでしょうか?