Laravel7 resource使用時のメソッドとURIの対応表

Laravel7 resource使用時のメソッドとURIの対応表

ルーティング設定時にRoute::resouceを使用した際にエラー「 Route [xxx.xxx] not defined. 」が発生して少し確認に手こずったので、メソッドとURIの関係性をメモしておきます。

環境

  • OS windows10 pro 64bit
  • Composer 1.10.5
  • PHP 7.4.5
  • MariaDB 10.4.12
  • Laravel Framework 7.6.2

※windows10に Laravel のインストールはこちら

サンプルコントローラー作成

artisanコマンドでコントローラー作成時に–resourceを指定して、CRUDに対応したメソッドを自動生成します。
ここでは「PhotoController」として作成します。

php artisan make:controller PhotoController --resource

app\Http\Controllers\PhotoController.phpが作成されます。

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

class PhotoController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        //
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        //
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        //
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        //
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        //
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        //
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        //
    }
}

ルーティング作成

作成したPhotoControllerを一括でルーティングするために、Route::resourceを使用します。

Route::resources([
    'photos' => 'PhotoController'
]);

対応表

上記の手順で、resources利用した際の「各メソッド」と「URI」の対応表は下記の画像の通りとなります。