前提・実現したいこと
度々の投稿失礼します。簡単なラーメン屋投稿アプリを作っているのですが、お店画像のアップロードがうまくいきません。index.blade.phpにbootostrapのcardsを使用して各店の画像を表示していく箇所で詰まっています。コンソールでは画像がnot foundとなっています。解決方法を教えてくださると大変光栄でございます。
発生している問題・エラーメッセージ
各店の画像が表示されない
該当のソースコード
/Applications/MAMP/htdocs/ramenmap/resources/views/index.blade.php
@extends('layout') @section('content') @auth <div class="text-right"> <a href={{ route('shop.new') }} class='btn btn-outline-info'>お店投稿</a> </div> @endauth <h1>お店一覧</h1> @foreach ($shops as $shop) <div class="card mb-3" style="max-width: 540px;"> <div class="row no-gutters"> <div class="col-md-4"> {{-- @foreach($image as $i) @if($i!=null) <img src="/images/{{$i->image}}" class="card-img"> @endif @endforeach --}} {{-- {{ dd($shop->image) }} --}} <img src="{{ $shop->image }}" class="card-img"> </div> <div class="col-md-8"> <div class="card-body"> <h5 class="card-title"> <a href={{ route('shop.detail', ['id' => $shop->id]) }}>{{ $shop->name }}</a> </h5> <p class="card-text">{{ $shop->category->name }} @if ($shop->category->name != $shop->subcategory->name) / {{ $shop->subcategory->name }} @endif <p class="card-text">{{ $shop->address }}</p> <p class="card-text">{{ $shop->user->name }}</p> <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p> </div> </div> </div> </div> @endforeach @endsection
/Applications/MAMP/htdocs/ramenmap/app/Http/Controllers/ShopController.php
<?php namespace App\Http\Controllers; use App\Shop; use App\Category; use App\SubCategory; use App\Pic; use Illuminate\Http\Request; use Intervention\Image\ImageManagerStatic as Image; class ShopController extends Controller { public function __construct() { $this->middleware('auth')->except(['index', 'show']); } /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index() { $shops = Shop::latest()->get(); $image = Pic::all(); return view('index', ['shops'=>$shops, 'image'=>$image]); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create(Request $request) { $shop = new Shop(); $shop->name = $request->name; $categories = Category::all()->pluck('name', 'id'); $subcategories = SubCategory::all()->pluck('name', 'id'); $image = Pic::all(); return view('new', ['categories' => $categories, 'subcategories' => $subcategories, 'image' => $image]); } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $shop = new Shop; $user = \Auth::user(); $shop->name = request('name'); $shop->address= request('address'); $shop->category_id = request('category_id'); $shop->subcategory_id = request('subcategory_id'); $shop->user_id = $user->id; $shop->image = request('image'); $shop->save(); // dd($shop); // $request->validate([ // 'image'=>'required|image|mimes:jpg,jpeg,png|max:2000' // ]); $file = $request->file('image'); // dd($file); $fileName = str_random(20).'.'.$file->getClientOriginalExtension(); // dd($fileName); Image::make($file)->save(public_path('images/'.$fileName)); $pic=new Pic; $pic->image = $fileName; $pic->save(); return redirect()->route('shop.detail', ['id' => $shop->id]); } /** * Display the specified resource. * * @param \App\Shop $shop * @return \Illuminate\Http\Response */ public function show($id) { $shop = Shop::find($id); $user = \Auth::user(); if ($user) { $login_user_id = $user->id; } else { $login_user_id = ''; } return view('show', ['shop' => $shop, 'login_user_id'=>$login_user_id]); } /** * Show the form for editing the specified resource. * * @param \App\Shop $shop * @return \Illuminate\Http\Response */ public function edit(Shop $shop, $id) { $shop = Shop::find($id); $categories = Category::all()->pluck('name', 'id'); $subcategories = SubCategory::all()->pluck('name', 'id'); return view('edit', ['shop' => $shop, 'categories' => $categories, 'subcategories' => $subcategories]); } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param \App\Shop $shop * @return \Illuminate\Http\Response */ public function update(Request $request, Shop $shop, $id) { $shop = Shop::find($id); $shop->name = request('name'); $shop->address = request('address'); $shop->category_id = request('category_id'); $shop->subcategory_id = request('subcategory_id'); $shop->save(); return redirect()->route('shop.detail', ['id' => $shop->id]); } /** * Remove the specified resource from storage. * * @param \App\Shop $shop * @return \Illuminate\Http\Response */ public function destroy($id) { $shop = Shop::find($id); $shop->destroy($id); return redirect('/shops'); } }
/Applications/MAMP/htdocs/ramenmap/routes/web.php
<?php Route::get('/shops', 'ShopController@index')->name('shop.list'); Route::get('/shop/new', 'ShopController@create')->name('shop.new'); Route::post('/shop', 'ShopController@store')->name('shop.store'); Route::get('/shop/edit/{id}', 'ShopController@edit')->name('shop.edit'); Route::post('/shop/update/{id}', 'ShopController@update')->name('shop.update'); Route::get('/shop/{id}', 'ShopController@show')->name('shop.detail'); Route::delete('/shop/{id}', 'ShopController@destroy')->name('shop.destroy'); Route::get('/', function() { return redirect('/shops'); }); Auth::routes(); Route::get('/home', 'HomeController@index')->name('home');
/Applications/MAMP/htdocs/ramenmap/app/Shop.php
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Shop extends Model { protected $fillable = [ 'name', 'address', 'category_id', 'subcategory_id', 'user_id', 'imgage', ]; public function category() { return $this->belongsTo('App\Category'); } public function subcategory() { return $this->belongsTo('App\SubCategory'); } public function user() { return $this->belongsTo('App\User'); } public function pic() { return $this->belongsTo('App\Pic'); } }
/Applications/MAMP/htdocs/ramenmap/app/Pic.php
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Pic extends Model { // }
試したこと
ググりながら色々とコードを書き直しましたがうまくいかずです。
パスの仕組みが漠然としています。
補足情報(FW/ツールのバージョンなど)
PHP 7.1.23
Laravel Framework 5.7.2
回答3件
あなたの回答
tips
プレビュー