画像アップロード機能を投稿フォームにつける【初心者のLaravel入門講座】

Laravel入門講座

Laravelで投稿フォームに画像のアップロード機能を付ける方法を解説していきますね。

画像を保存するために、storeAs と getClientOriginalNameを使っていきます。

*バージョンはLaravel8を使っています。

画像アップロード機能を投稿フォームにつける【初心者のLaravel入門講座】

手順は次のとおりです。

  1. 画像のパスをいれるカラムをテーブルに作成する
  2. フォームの中に画像をアップロード機能を付ける
  3. シンボリックリンクを貼る
  4. コントローラーに画像保存処理を記述する
  5. 投稿テストをする
  6. 表示テストをする

①画像のパスをいれるカラムをテーブルに作成する

マイグレーションファイルに、画像のパスをいれるカラムを作っておきましょう。

前後の部分もあわせると、このような感じに作ります。

②フォームの中に画像をアップロード機能を付ける

フォームの中に画像をアップロードする機能を付けます。

ブラウザで表示させると、このようなファイル選択ボタンができています。

③シンボリックリンクを貼る

次に、こちらのコマンドでシンボリックリンクを作成します。

シンボリックリンクとは、ショートカットのようなものです。

コマンド実行後、publicフォルダ内にstorageフォルダへのリンクが貼られます。

 

なぜシンボリックリンクが必要なの?

シンボリックリンクはわかりにくいのですが、Laravelで画像を保存するうえで、わりと重要です。

デフォルトでは、画像はstorageフォルダ内に保存されます。

ですがLaravelのプロジェクトをWeb上に公開した時は、ユーザーはpublicフォルダのファイルにしかアクセスできません。

つまり、storageフォルダ内の画像がユーザーに表示されなくなってしまうのです。

シンボリックリンクを貼ることでstorageフォルダとpublicフォルダをつなげられ、この問題を回避できます。

④コントローラーに画像保存処理を記述する

最後に、コントローラーに画像を保存するコードを記述していきましょう。

画像ファイルのINPUTタグのname属性が【image】であるとします。

<input id=”image” type=”file” name=”image“>

コントローラーには、下記のように記述します。

画像の保存に関する記述は、次のように入れました。

        if(request(‘image’)){
            $filename=request()->file(‘image’)->getClientOriginalName();
            $inputs[‘image’]=request(‘image’)->storeAs(‘保存場所’, $filename);
        }

$filenameで、ファイル名を指定しています。

元々のファイル名でファイルを保存するには、getClientOriginalNameを使います。

保存するために、storeAsを使用しています。

⑤投稿テストをする

それでは、実際にフォームに画像を入れて投稿をしてみます。

フォームを送信した後、データベースには次のように保存されました。

⑥表示テストをする

最後に、保存された画像ファイルをimg srcタグに埋め込み、ブラウザに表示してみます。

bladeファイルには、次のように記述しました。

ブラウザには、下記のように表示されました。

さいごに

無事に画像が表示されましたか?

画像表示は、ちょっとしたことで、うまくいかなかったりします(←経験則)

もしうまくいかなかった場合は、下記の点をチェックしてください。

  • ローカルフォルダをチェック:フォルダにちゃんとファイルが保存されているか
  • ブラウザのソースコードをチェック:ブラウザのパスは正しく入っているか

必要に応じて、保存場所やパスの指定を変えてくださいね。

Laravel入門講座

【Laravelの教科書・プレゼント】

Junko
Laravelの使い方を覚えたい!と思ったら、ぜひ、役立ててほしいです。 基礎編は無料でプレゼント中です♪
ひつじプログラマ
会員制サイトをいちから作っていくよ。ボタンをクリックして詳細を見てね。
Laravelの教科書の詳細を見る

最新のLaravel10版テキストに加え、Laravel8版・Laravel9版もご用意しています♪

【無料プレゼント】

「LaravelでWebアプリをいちから作れるようになりたい!」

そんなLaravel初心者のあなたへ【Laravelの教科書】基礎編プレゼント中! 会員制フォーラムサイトを学習しながら作れます。

詳細はこちらをクリック

最新のLaravel10版テキストに加え、Laravel8版・Laravel9版もご用意しています♪

Laravelの本を書きました。


ひつじが目印♪
クリックするとamazonページへ。

Laravelの使い方を分かりやすく解説した書籍を出版しました。書店やAmazon等のオンラインショップにて販売中です。
Laravel10対応。Laravel11サポートガイドもご用意しています。詳しくは下記ボタンをクリック♪

書籍の詳細を見てみる

Laravelの本を書きました。


ひつじが目印♪
クリックするとamazonページへ。

Laravel10対応

Laravelの使い方を分かりやすく解説した書籍を出版しました。書店やAmazon等のオンラインショップにて販売中です。

書籍の詳細を見てみる

 

Laravelの教科書限定コミュニティ【Laravelの教科書ラボ】はじめました。
デプロイ講座付。StripeやChatGPT連携など過去10回分のセミナー動画視聴可能。

Laravel実践スキルをのばしたい方におすすめです。

ラボの案内を見てみる

Twitter始めました。
40代からプログラミング!
タイトルとURLをコピーしました