■やりたいこと→フォルダに保存された画像を表示したい
フォームから画像を登録し、指定フォルダに保存されていることを確認できますがViewで表示できずにいます。尚、画像を保存しているディレクトリと公開ディレクトリを紐付けるための、シンボリックリンクは実行済み(php artisan storage:link)です。パスが合っていないと思うのですが、解決できずにいるので何かご教示をお願いします。
■現状ビュー画像
![
■画像ファイル構成
■DB(PHP My Adimin)
各ファイルや構成は以下の通りです。
✳️Laravel バージョン 6.20.8
■index.php(ビュー)
@extends('layouts.app') @section('content') <table class="table table-hover"> <thead class="thead-dark"> <tr> <th scope="col">社員番号</th> <th></th> <th scope="col">名前</th> <th scope="col">所属事業所</th> <th scope="col" colspan="4" class="d-none d-sm-table-cell">貸与品</th> <th></th> </tr> </thead> <tbody> @foreach($employees as $employee) <tr> <td class="align-middle" scope="row">{{ $employee->employee_id }}</td> <td><img src="{{ asset('storage/employee_image/' . $employee->employee_image) }}" alt="画像" class="rounded-circle" width="50" height="50"></td> <td class="align-middle" scope="row">{{ $employee->employee_name }}</td> <td class="align-middle" scope="row">{{ $employee->office }}</td> <td class="d-none d-sm-table-cell"> @foreach($employee->goods as $goods) <p class="vertical-middle">制服:{{ $goods->uniform }}|防寒着:{{ $goods->winter_clothes }}|靴:{{ $goods->shoes }}|その他:{{ $goods->other }}</p> @endforeach </td> <td class="align-middle" scope="row"><a href="{{ route('employee_create.show',$employee->id) }}" class="btn btn-primary">詳細</a></td> </tr> @endforeach </tbody> </table> @endsection
■EmployeesController.php(コントローラー)
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Employee; use App\Goods; class EmployeesController extends Controller { public function index() { $employees = Employee::with('goods')->get(); return view('index', ['employees' => $employees, ]); } public function create() { $user =\Auth::user(); return view('employee_create'); } public function store(Request $request) { $request->validate([ 'employee_image' => 'required', 'employee_id' => 'required', 'employee_name' => 'required', 'office' => 'required', 'uniform' => 'required', 'winter_clothes' => 'required', 'shoes' => 'required', ]); $employee = new Employee; $employee->employee_id = $request->input('employee_id'); $employee->employee_name = $request->input('employee_name'); $employee->office = $request->input('office'); $employee->employee_image = $request->file('employee_image')->store('public/employee_image'); $employee->save(); $goods = new Goods; $goods->uniform = $request->input('uniform'); $goods->winter_clothes = $request->input('winter_clothes'); $goods->shoes = $request->input('shoes'); $goods->other = $request->input('other'); $goods->memo = $request->input('memo'); $goods->employee_id = $employee->id; $goods->save(); return redirect(route('employee_create.index'))->with('flash_message','社員を登録しました'); } } }
■Employee.php(モデル)
namespace App; use IlluminateSupportFacadesDB; use Illuminate\Database\Eloquent\Model; class Employee extends Model { protected $fillable = ['id','emlpoyee_id','employee_name','office','employee_image']; protected $guarded = array('id'); public function goods() { return $this->hasMany(Goods::class); } }
■create_employees_table.php(マイグレーション)
<?php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; class CreateEmployeesTable extends Migration { public function up() { Schema::create('employees', function (Blueprint $table) { $table->bigIncrements('id'); $table->unsignedBigInteger('employee_id'); $table->string('employee_name'); $table->string('office'); $table->string('employee_image')->nullable(); $table->timestamps(); }); } public function down() { Schema::dropIfExists('employees'); } }
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。