LoginSignup
16
19

More than 3 years have passed since last update.

Laravel 画像をアップロードして表示する

Last updated at Posted at 2020-05-14

目的

  • アプリケーションに画像をアップロードして別画面で表示する方法をまとめる

環境

  • ハードウェア環境
項目 情報
OS macOS Catalina(10.15.3)
ハードウェア MacBook Pro (16-inch ,2019)
プロセッサ 2.6 GHz 6コアIntel Core i7
メモリ 16 GB 2667 MHz DDR4
グラフィックス AMD Radeon Pro 5300M 4 GB Intel UHD Graphics 630 1536 MB
  • ソフトウェア環境
項目 情報 備考
PHP バージョン 7.4.3 Homwbrewを用いて導入
Laravel バージョン 7.0.8 commposerを用いて導入
MySQLバージョン 8.0.19 for osx10.13 on x86_64 Homwbrewを用いて導入

事前情報

  • 下記の方法、またはそれに準ずる方法で認証機能のついたLaravelアプリが存在すること。
  • 既存のマイグレーションファイルがマイグレートされていること。
  • ログインユーザ毎に別々の画像のアップロードと表示をすることができる様に実装する。(他のログインユーザがアップロードした画像は表示されない)

概要

  1. テーブルの作成
  2. ルーティングの記載
  3. コントローラの記載
  4. ビューの記載
  5. シンボリックリンクの作成
  6. 確認

詳細

  1. テーブルの作成

    1. アプリ名ディレクトリで下記コマンドを実行してモデルファイルとマイグレーションファイルを同時に作成する。

      $ php artisan make:model Image --migration
      
    2. 下記にファイルが作成された事を確認する。

      • アプリ名ディレクトリ/app/Image.php
      • アプリ名ディレクトリ/database/migrations/YYYY_MM_DD_XXXXXX_create_images_table.php
    3. アプリ名ディレクトリで下記コマンドを実行してマイグレーションファイルを開く。

      $ vi database/migrations/YYYY_MM_DD_XXXXXX_create_images_table.php
      
    4. 開いたマイグレーションファイルを下記の様に記載する。

      アプリ名ディレクトリ/database/migrations/YYYY_MM_DD_XXXXXX_create_images_table.php
      <?php
      
      use Illuminate\Database\Migrations\Migration;
      use Illuminate\Database\Schema\Blueprint;
      use Illuminate\Support\Facades\Schema;
      
      class CreateImagesTable extends Migration
      {
          /**
           * Run the migrations.
           *
           * @return void
           */
          public function up()
          {
              Schema::create('images', function (Blueprint $table) {
                  $table->id();
                  //下記を追記する
                  $table->foreignId('user_id');
                  $table->string('file_name');
                  //上記までを追記する
                  $table->timestamps();
              });
          }
      
          /**
           * Reverse the migrations.
           *
           * @return void
           */
          public function down()
          {
              Schema::dropIfExists('images');
          }
      }
      
    5. アプリ名ディレクトリで下記コマンドを実行してマイグレーションを行う。

      $ php artisan migrate
      
  2. ルーティングの記載

    1. アプリ名ディレクトリで下記コマンドを実行してシンボリックリンクを作成する。

      $ php artisan storage:link
      
    2. アプリ名ディレクトリで下記コマンドを実行してルーティングファイルを開く。

      $ vi routes/web.php
      
    3. 開いたルーティングファイルを下記の様に修正する。

      アプリ名ディレクトリ/routes/web.php
      <?php
      
      use Illuminate\Support\Facades\Route;
      
      /*
      |--------------------------------------------------------------------------
      | Web Routes
      |--------------------------------------------------------------------------
      |
      | Here is where you can register web routes for your application. These
      | routes are loaded by the RouteServiceProvider within a group which
      | contains the "web" middleware group. Now create something great!
      |
      */
      
      Route::get('/', function () {
          return view('welcome');
      });
      
      Auth::routes();
      
      Route::get('/home', 'HomeController@index')->name('home');
      
      //下記を追記
      //画像をアップロードするページ
      Route::get('/upload', 'ImageController@input');
      //画像を保存したり画像名をDBに格納する部分
      Route::post('/upload', 'ImageController@upload');
      //保存した画像を表示するページ
      Route::get('/output', 'ImageController@output');
      //上記までを追記
      
  3. コントローラの記載

    1. アプリ名ディレクトリで下記コマンドを実行してコントローラファイルを作成する。

      $ php artisan make:controller ImageController
      
    2. 下記のコントローラファイルが作成される。

      • アプリ名ディレクトリ/app/Http/Controllers/ImageCotroller.php
    3. アプリ名ディレクトリで下記コマンドを実行してコントローラファイルを開く。

      vi app/Http/Controllers/ImageController.php
      
    4. 開いたコントローラファイルを下記の様に修正する。

      アプリ名ディレクトリ/app/Http/Controllers/ImageCotroller.php
      <?php
      
      namespace App\Http\Controllers;
      //下記を追加する
      use Illuminate\Support\Facades\Auth;
      use Illuminate\Http\Request;
      //下記を追加する
      use App\Image;
      
      class ImageController extends Controller
      {
          //下記を追加する
          public function input()
          {
              return view('image.input');
          }
      
          public function upload(Request $request)
          {
              $this->validate($request, [
                  'file' => [
                      // 必須
                      'required',
                      // アップロードされたファイルであること
                      'file',
                      // 画像ファイルであること
                      'image',
                      // MIMEタイプを指定
                      'mimes:jpeg,png',
                  ]
              ]);
      
              if ($request->file('file')->isValid([])) {
                  $path = $request->file->store('public');
      
                  $file_name = basename($path);
                  $user_id = Auth::id();
                  $new_image_data = new Image();
                  $new_image_data->user_id = $user_id;
                  $new_image_data->file_name = $file_name;
      
                  $new_image_data->save();
      
                  return redirect('/output');
              } else {
                  return redirect()
                      ->back()
                      ->withInput()
                      ->withErrors();
              }
          }
      
          public function output() {
              $user_id = Auth::id();
              $user_images = Image::whereUser_id($user_id)->get();
              return view('image.output', ['user_images' => $user_images]);
          }
          //上記までを追記
      }
      
  4. ビューの記載

    1. アプリ名ディレクトリで下記コマンドを実行してビューファイルを格納するディレクトリを作成する。

      $ mkdir resources/views/image
      
    2. アプリ名ディレクトリで下記コマンドを実行してビューファイルを作成する。

      $ touch resources/views/image/input.blade.php
      $ touch resources/views/image/output.blade.php
      
    3. アプリ名ディレクトリで下記コマンドを実行して画像をアップロードするビューファイルを開く。

      $ vi resources/views/image/input.blade.php
      
    4. 開いたビューファイルを下記の様に記載する。

      アプリ名ディレクトリ/resources/views/image/input.blade.php
      @extends('layouts.app')
      
      @section('content')
      <!-- エラーメッセージ。なければ表示しない -->
      @if ($errors->any())
      <ul>
          @foreach($errors->all() as $error)
          <li>{{ $error }}</li>
          @endforeach
      </ul>
      @endif
      
      <!-- フォーム -->
      <form action="/upload" method="POST" enctype="multipart/form-data">
          @csrf
      
          <label for="photo">画像ファイル:</label>
          <input type="file" class="form-control" name="file">
          <br>
          <input type="submit">
      </form>
      @endsection
      
    5. アプリ名ディレクトリで下記コマンドを実行して画像をアップロードするビューファイルを開く。

      $ vi resources/views/image/output.blade.php
      
    6. 開いたビューファイルを下記の様に記載する。

      アプリ名ディレクトリ/resources/views/image/output.blade.php
      @extends('layouts.app')
      
      @section('content')
          <a href="/upload">画像のアップロードに戻る</a>
          <br>
          @foreach ($user_images as $user_image)
              <img src="{{ asset('storage/' . $user_image['file_name']) }}">
              <br>
          @endforeach
      @endsection
      
  5. シンボリックリンクの作成

    1. アプリ名ディレクトリで下記コマンドを実行してstrageディレクトリへのシンボリックリンクを作成する。

      $ php artisan storage:link
      
  6. 確認

    1. アプリ名ディレクトリで下記コマンドを実行してローカルサーバを起動する。

      $ php artisan serve
      
    2. 下記にアクセスする。

    3. 画面右上の 「LOGIN」もしくは「REGISTER」からログインもしくは新規登録を行う。

      Laravel.png

    4. 下記にアクセスする。

    5. ブラウザ上で下記の様に表示される事を確認する。

      Laravel.png

    6. 「ファイルを選択」をクリックして任意の画像ファイルを開き、「送信」をクリックする。

    7. 下記の様に送信した画像が表示される事を確認する。

      Laravel.png

    8. 同アプリで現在ログインしているユーザとは別にユーザを作成しログインを行い、先とは違う画像をアップロードして先の画像とは別の画像表示される事を確認する。

16
19
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
19