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

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

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

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Laravel

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

PHP

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

Amazon S3

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

AWS(Amazon Web Services)

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

Q&A

解決済

2回答

3275閲覧

AWS S3内の写真がLaravelのアプリ上で表示されません。

helloo

総合スコア11

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Laravel

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

PHP

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

Amazon S3

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

AWS(Amazon Web Services)

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

0グッド

1クリップ

投稿2020/04/20 08:07

前提・実現したいこと

**前提:**Laravelで作成したアプリをHerokuにデプロイしました。
**実現したいこと:**AWS S3のバケット内にある写真をアプリ上で表示したい。

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

特にこれといったエラーメッセージはありません。
写真を投稿すると指定のページへリダイレクトしてしまいアプリ上では投稿した画像が表示されません。
S3のバケット内には投稿した写真が存在します。

該当のソースコード

routes/web.php

php

1<?php 2 3/* 4|-------------------------------------------------------------------------- 5| Web Routes 6|-------------------------------------------------------------------------- 7| 8| Here is where you can register web routes for your application. These 9| routes are loaded by the RouteServiceProvider within a group which 10| contains the "web" middleware group. Now create something great! 11| 12*/ 13 14Route::get('login'); 15 16Route::group(['middleware' => 'auth'], function(){ 17 Route::get('/', 'StoriesController@index'); 18 Route::post('/', 'StoriesController@store'); 19}); 20 21Route::group(['middleware' => 'auth'], function(){ 22 Route::get('stories/create', 'StoriesController@add'); 23 Route::post('stories/create', 'StoriesController@upload'); 24 Route::get('/stories/delete', 'StoriesController@delete'); 25}); 26 27Route::get('/profile/delete', 'ProfileController@delete'); 28 29Route::group(['middleware' => 'auth','name'=>'profile'], function () { 30 Route::get('/profile/edit', 'ProfileController@edit'); 31 Route::post('/profile/edit', 'ProfileController@update'); 32 Route::post('/profile/create', 'ProfileController@create'); 33 Route::get('profile/create3', 'ProfileController@index3'); 34}); 35 36Route::get('/home', 'StoriesController@index')->name('home'); 37 38Auth::routes(); 39 40

app/Http/Controller/StoriesController.php※写真を投稿するアクションはstoreアクションです。

php

1<?php 2 3namespace App\Http\Controllers; 4 5use Illuminate\Http\Request; 6use App\Http\Controllers\Controller; 7use App\Story; 8use App\Profile; 9use Auth; 10use App\Posts; 11use App\History; 12use App\Attachment; 13use Carbon\Carbon; 14use Storage; 15 16class StoriesController extends Controller 17{ 18 19 public function __construct() 20 { 21 $this->middleware('auth'); 22 } 23 24 public function index(Request $request) 25 { 26 $images = Attachment::all(); 27 $cond_title = $request->cond_title; 28 if ($cond_title != '') { 29 $posts = Profile::where('title', $cond_title)->get(); 30 } else { 31 $posts = Profile::all(); 32 } 33 return view('stories.index2', compact('images','posts','cond_title')); 34 } 35 36 public function add() 37 { 38 return view('stories.create2'); 39 } 40 41 public function store(Request $request) 42 { 43 $form = $request->file('images'); 44 $d = new \DateTime(); 45 $d->setTimeZone(new \DateTimeZone('Asia/Tokyo')); 46 $dir = $d->format('Y/m'); 47 $path = Storage::disk('s3')->putFile('/',$form,'public'); 48 $data = $request->except('_token'); 49 50 foreach ($data['images'] as $k => $v) { 51 52 $filename = ''; 53 54 $attachments = Attachment::take(1)->orderBy('id', 'desc')->get(); 55 56 foreach ($attachments as $attachment) { 57 $filename = $attachment->id + 1 . '_' . $v->getClientOriginalName(); 58 } 59 unset($attachment); 60 61 if ($filename == false) { 62 $filename = 1 . '_' . $v->getClientOriginalName(); 63 } 64 $v->storeAs($path, $filename); 65 66 $attachment_data = [ 67 'path' => $path, 68 'name' => $filename 69 ]; 70 71 $a = new Attachment(); 72 $a->fill($attachment_data)->save(); 73 } 74 unset($k, $v); 75 return redirect('/'); 76 } 77 78public function delete(Request $request) 79 { 80 $images = Attachment::find($request->id); 81 $images->delete(); 82 return redirect('/'); 83 } 84 85 // public function upload(Request $request) 86 // { 87 // $this->validate($request, [ 88 // 'file' => [ 89 // 'required', 90 // 'file', 91 // 'image', 92 // 'mimes:jpeg,png', 93 // ] 94 // ]); 95 96 // if ($request->file('images')->isValid([])) { 97 // $path = Storage::disk('s3')->putFile('/',$form,'public'); 98 // return view('stories.index2')->with('filename', basename($path)); 99 // } else { 100 // return redirect('/') 101 // ->back() 102 // ->withInput() 103 // ->withErrors(); 104 // } 105 // } 106} 107

resources/views/stories/create2.blade.php※写真を投稿するページ

php

1@extends('layouts.front2') 2@section('title','StoryCreate') 3 4@section('content') 5<link href="{{ asset('/css/main22.css' )}}" rel="stylesheet"> 6 7<div class="poststory"> 8 <h1>Post Story</h1> 9</div> 10@if ($errors->any()) 11<ul> 12 @foreach($errors->all() as $error) 13 <li>{{ $error }}</li> 14 @endforeach 15</ul> 16@endif 17<form action="{{ url('/') }}" method="POST" enctype="multipart/form-data"> 18 19 <div class="form"> 20 <label for="photo" class="file">Choose Image or Video</label> 21 <div class="post"> 22 <input type="file" class="here" name="images"> 23 24 </div> 25 </div> 26 <br> 27 </div> 28 29 {{ csrf_field() }} 30 <div class="post"> 31 <div class="btn postbtn"> 32 <input type="submit" value="post" /> 33 </div> 34 </div> 35</form> 36 37@endsection 38

resources/views/stories/index2.blade.php※投稿した写真を表示したいページ

php

1@extends('layouts.front2') 2@section('title','mainpage') 3 4@section('content') 5 6<link rel="stylesheet" href="{{ asset('css/main2.css') }}"> 7 8<div class="profile"> 9 <div class="name"> 10 @guest 11 <a class="nav-link2" href="{{ route('register')}}">{{ __('Create Accout!')}}</a> 12 @else 13 <a id="navbarDropdown" class="nav-link2" href="#" role="button"> 14 {{ Auth::user()->name }}<span class="caret"></span></a> 15 <form id="logout-form" action="{{ route('logout') }}" method="POST" style="display: none;"> 16 @csrf 17 </form> 18 @endguest 19 </div> 20 21<div class="aboutme"> 22 <tbody> 23 @foreach($posts as $profile) 24 <tr> 25 <td>{{ \Str::limit($profile->title, 100) }}</td> 26 <td>{{ \Str::limit($profile->body, 250) }}</td> 27 </tr> 28 <a href="{{ action('ProfileController@delete', ['id' => $profile->id]) }}">delete</a> 29 <a href="{{ action('ProfileController@update', ['id' => $profile->id]) }}" class="update">update</a> 30 @endforeach 31</tbody> 32<br> 33</div> 34</div> 35 36<div class="new"> 37 <div class="newtitle"> 38 <h1>New</h1> 39 </div> 40 <div class="container1"> 41 @foreach ($images as $image) 42 <img src="{{ $image->path }}" class="images" style="height: 250px; width: 250px; border-radius: 50%;"> 43 <a href="{{ action('StoriesController@delete', ['id' => $image->id]) }}">delete</a> 44 @endforeach 45 <div class="more"> 46 more... 47 </div> 48 </div> 49</div> 50 51 52{{ csrf_field() }} 53@endsection

試したこと

必要な環境変数の設定。

初心者で至らぬ点は多々あるかとは思いますが、ご教授いただけると幸いです。
何卒よろしくお願いします。

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

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

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

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

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

guest

回答2

0

bucketの設定が「公開」になっているかも確認すべきポイントかと思います。

投稿2020/05/07 12:00

supermaruetsu

総合スコア148

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

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

helloo

2020/05/07 15:07

回答ありがとうございます。 S3を確認したところアクセスの箇所に”オブジェクトは公開できます”とありました。 またバケット内にある画像を公開しても変化は見受けられませんでした…。
guest

0

ベストアンサー

HTML

1 <img src="{{ $image->path }}"

ここで $image->path が src に書かれるわけなので、この結果は「S3 のバケットの中のパス」となっていなければなりません。
S3 にアクセスしてオブジェクトの概要を見ると、オブジェクトURL が出ますが、それと同じになってますか?

投稿2020/04/20 09:05

tacsheaven

総合スコア13703

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

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

helloo

2020/04/21 08:11

回答ありがとうございます。 写真を投稿すると、投稿した画像のimg要素が表示されないので、srcにS3のバケットの中のパスになっているのか確認できないのですが、このような場合はどのように対処すればよろしいでしょうか。 返信いただけると幸いです。 よろしくお願いします。
tacsheaven

2020/04/21 08:14

表示しているブラウザで、「ソースを表示」とか、あるいは開発ツールで見るとかすれば、img 要素のソース部分が見えるはずですよ。
helloo

2020/04/21 08:29

返信ありがとうございます。 開発ツールは掲載したコードの通りなのですが、ブラウザ上で写真を投稿しソースを表示するとimg要素が存在していない状況です。 よろしくお願いします。
tacsheaven

2020/04/21 08:42

とすると、$images が空、ということでしょうから、そこを確認しましょう。
helloo

2020/04/21 09:10

確認してみます。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問