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

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

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

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

Amazon S3

Amazon S3 (Simple Storage Service)とはアマゾン・ウェブ・サービスが提供するオンラインストレージサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

2回答

4261閲覧

Laravelアプリの本番環境で画像投稿時404 Not Foundが出てしまう

atsuya-koshida

総合スコア1

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

Amazon S3

Amazon S3 (Simple Storage Service)とはアマゾン・ウェブ・サービスが提供するオンラインストレージサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/05/27 03:22

発生している問題・エラーメッセージ

Laravelを使ったアプリケーションにflysystem-aws-s3-v3をインストールし、画像を投稿するとS3にアップロードされるように実装をしました。
ローカル環境では投稿・画像の表示共に上手くいっていたので本番環境にデプロイし、本番環境で画像を投稿する機能を使うと404 Not Foundが出てしまいました。

config/filesystems.phpは以下のようになっており、.envに環境変数を記述しています。
(ローカル・本番環境共にS3にアップロードされるようにしています)

filesystems.php 's3' => [ 'driver' => 's3', 'key' => env('AWS_ACCESS_KEY_ID'), 'secret' => env('AWS_SECRET_ACCESS_KEY'), 'region' => env('AWS_DEFAULT_REGION'), 'bucket' => env('AWS_BUCKET'), 'url' => env('AWS_URL'), 'endpoint' => env('AWS_ENDPOINT'), ],

そしてこちらが画像投稿機能のソースコードになります。

php

1public function store(PostRequest $request, Post $post) 2 { 3 $post->fill($request->all()); 4 5 if(!is_null($request['image'])){ 6 $file_path = Storage::disk('s3')->putfile('myprefix', $request->file('image'), 'public'); 7 $post->image = Storage::disk('s3')->url($file_path); 8 } 9 10 $post->save(); 11 }

試したこと

本番環境で最初に画像投稿機能を使った時に、本番環境に環境変数の設定をするのを忘れていたので
ローカル環境と同じ記述を本番環境の.envに記述してみました。
特に変わらなかったので~/.bash_profileとか色んなところに書いてみたりnginxの設定を見たりしたのですが原因がわからず、こちらで質問させていただきました…

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

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

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

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

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

guest

回答2

0

ベストアンサー

404 Not Found
なので本番環境のURLが正しいか見てみると良さそうかな…
public function store(PostRequest $request, Post $post)に処理が来てるところから調べてみてはいかがでしょう。

投稿2020/05/27 03:58

rururu3

総合スコア5545

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

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

atsuya-koshida

2020/05/27 05:01

rururu3さん、回答ありがとうございます! storeアクション内でLog::debug($request)を書いてログを確認したところ、リクエストに値は入っていましたが以下のようなエラーが出ていました! 【Error retrieving credentials from the instance profile metadata service. (Client error: `GET http://169.254.169.254/latest/meta-data/iam/security-credentials/` resulted in a `404 Not Found` response:】 本アプリケーションのURLはhttp://18.180.87.69/なので、http://169.254.169.254というURLが出ているのが気になりますが原因がわかりません
rururu3

2020/05/27 05:09

169.254.169.254はアメリカっぽいのでAWS指してそうですね
atsuya-koshida

2020/05/27 05:10

rururu3さん!いけました! 本番環境の.envを再度書き直して、頂いた記事を参考にキャッシュをクリアしたら投稿ができるようになりました…! 本当にありがとうございます!
rururu3

2020/05/27 05:11

よかったです!cache clear結構忘れるんですよね
atsuya-koshida

2020/05/27 05:12

キャッシュにも気をつけるようにします!
guest

0

まずはAWS上にはアップロードされているかどうかを確かめてください。
アップロードされているようであれば、URLが間違っている、AWSの公開設定が間違っているなどが原因の可能性が高く
アップロードされていないようなら、Laravel、サーバ側の設定不良の可能性が高いです

投稿2020/05/27 03:27

mikkame

総合スコア5036

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

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

atsuya-koshida

2020/05/27 03:52

mikkameさん、回答ありがとうございます! AWS上にはローカルからのアップロードはされていますが、本番環境からのアップロードはされていませんでした。 なのでLaravelかサーバ側の設定不良になるんでしょうか、やはりnginxの設定ですかね…????
mikkame

2020/05/27 03:54

本番で明確なエラーが出ない場合、テスト用のS3に正常にアップロードされていたりしませんか?
atsuya-koshida

2020/05/27 04:02

テスト用のS3は作成していないのでアップロードはされていないと思われます。 nginxのエラーログを確認してみたのですがこちらは解決に役立ちそうでしょうか? "/home/webapp/laravel-portfolio2/public/50x.html" failed (2: No such file or directory), client: 131.147.108.220, server: _, request: "POST /post HTTP/1.1", upstream: "fastcgi://unix:/run/php-fpm/www.sock", host: "18.180.87.69", referrer: "http://18.180.87.69/post/create"
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問