質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

2回答

1468閲覧

Laral5.4で画像をMysqlに保存して表示できるようにしたい

yamaoka

総合スコア27

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2017/07/27 05:36

Laravel5.4でメッセージを投稿できるアプリを作っています。
現在文字しか投稿できないので画像も投稿できるようにしたいと考えています

画像を投稿してpublicディレクトリに保存し、それを表示することはできたのですが、画像をMysqlに保存してそれを表示できるようにしたいです。

現在はメッセージのマイグレーションファイルに

$table->binary('image')->nullable(); $table->char('extension',5)->nullable();

を追加して画像と拡張子を保存する場所を作りファイル名と、拡張子を保存しそれを表示させることができるのではと考えました

保存用のコントローラーは以下のような設定にして

$extension = array( 'png' => 'image/png', 'jpg' => 'image/jpeg', 'jpeg' => 'image/jpeg', 'gif' => 'image/gif', 'bmp' => 'image/bmp', ); DB::table('tweets')->insert([ 'body' => $request['body'], 'image' => $request['image'], 'extension' => $request['extension'], 'user_id' => $user_id, 'created_at'=>Carbon::now(), 'updated_at'=>$request['updated_at'], ]);

ビューではこのようにしました
{{ $tweet->image }}

これで表示しようとすると、C:\xampp\tmp\php164A.tmpというものが表示されます

Mysqlで確認したところ
id body image extension user_id
1 ああああああ [BLOB - 24 バイト] NULL 1
というような結果になっていました

ダイレクトにMysqlに保存しようとしているのですが、通常はpublicに一度保存をしてそれを異動させるようなプログラムを書くのが普通でしょうか?
今回のやり方でも間違いではないのでしょうか?

ここをこういう風に変更するとうまく行くのではないかなどもしありましたらご教授いただけないでしょうか?よろしくお願いします

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

そもそもDB内に保存はやめたほうがいいです。
https://teratail.com/questions/81233

LaravelならStorageでローカルに保存するかS3などに保存するかです。

投稿2017/07/27 07:25

kawax

総合スコア10377

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yamaoka

2017/07/27 09:25

なるほど・・・。投稿したメッセージと一緒に管理するのは画像もMysqlに入れちゃうのが便利かなと思ったのですがよくないのですね。 Mysqlに保存するのはその画像のあるパスだけにとどめるべきということでしょうか?
guest

0

さくっと見て気になったところは

$request['image']

はサーバーにアップされたファイルのテンポラリパスが入ってるのではと思います。

Laravelでのファイル中身取得に関しては
https://readouble.com/laravel/5.3/ja/requests.html
ファイル アップロードファイルの取得
を参考にしてみてはいかがでしょうか。

あとは、

{{ $tweet->image }}

ではバイナリデータを強引に文字列にしたものがそのまま出てくるかと思います。
Data URLスキームを利用しないといけないのではと思います。

投稿2017/07/27 05:45

rururu3

総合スコア5545

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yamaoka

2017/07/27 05:52

Data URLスキームというものをはじめて聞きました。 調べてみます。ご指摘ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問