環境:Windows10,XAMPP,HeidiSQL
データベース:テーブル名:shyouhin カラム:id,name,price,gazou,updated_at,created_at
画像をデータベースにアップロードしたい。
【コントローラー】
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\staff; use App\staffs; use App\shyouhin; use Validator; use App\Http\Requests\ShopRequest; use Illuminate\Support\Facades\DB; use DOMWrap\Document; use GuzzleHttp\Client; class shopController extends Controller { public function index() { return view('staff_add',['msg' => 'フォームを入力してください。']); } public function create(Request $request) { $data =new staff(); $data->name = $request->name; $data->password = $request->pass; $data->save(); $validate_rule = [ 'name' => 'required', 'pass' => 'required', ]; $this->validate($request,$validate_rule); return view('staff_add',['msg' => '登録完了致しました。']); } public function list(Request $request) { $items =DB::select('select * from staffs'); return view('staff_list',['items' => $items]); } public function top() { return view('top'); } public function shyouhintop() { return view('shyouhin_add',['msg' => '商品を入力してください。']); } public function shyouhin(Request $request) { $data = new shyouhin(); $data->name = $request->name; $data->price = $request->price; $data->gazou = $request->gazou; $data->save(); $validate_rule = [ 'name' => 'required', 'price' => 'required', ]; $this->validate($request,$validate_rule); return view('shyouhin_add',['msg' => '登録完了致しました。']); } public function shyouhinlist(Request $request) { $items =DB::select('select * from shyouhin'); return view('shyouhin_list',['items' => $items]); } public function delete(Request $request) { $data = shyouhin::find($request->id); $data->delete(); return redirect('/shyouhin/list'); } public function logintop() { return view('login',['msg' => 'ユーザー名、パスワードを入力してください。']); } public function login(Request $request) { $targets = DB::table('staffs')->get(); foreach($targets as $target) { if($request->name == $target->name && $request->pass == $target->password) { return redirect('/top'); } else { return view('login',['msg' => 'ユーザー名かパスワードに誤りがあります。']); } } } public function staff_delete(Request $request) { $data = staffs::find($request->id); $data->delete(); return redirect('/shop/list'); } }
【登録画面】
<!DOCtYPE html> <html> <head> <meta charset="UTF-8"> <title>ショップ</title> </head> <body> スタッフ追加<br /> <br /> <p>{{$msg}}</p> @if(count($errors)>0) <div> <ul> @foreach($errors->all() as $error) <li>{{$error}}</li> @endforeach </ul> </div> @endif <form method="post" action="/shyouhin" enctype="multipart/form-data"> <table> @csrf <tr><th>商品名を入力してください。</th><td> <input type="text" name="name" style="width:200px" value="{{old('name')}}"></td></th> <tr><th>価格を入力してください。</th><td> <input type="text" name="price" style="width:200px" value="{{old('price')}}"></td></th> <tr><th>画像を選択してください。</th><td> <input type="file" name="gazou" style="width:200px"></td></th> <tr><th></th><td><input type="submit" value="登録"></td></tr> </table> </form> <a href="/top">業務管理システム</a> </body> </html>
【表示画面】
<!DOCtYPE html> <html> <head> <meta charset="UTF-8"> <title>ショップ</title> </head> <body> 商品一覧<br /> <br /> <table border="2"> <tr> <th>商品</th> <th>価格</th> <th>画像</th> </tr> <form method="post" action="/shop/delete"> @csrf <tr> <td> @foreach($items as $item) <input type="radio" name="id" value="{{$item->id}}"> {{$item->name}}<br /> @endforeach </td> <td> @foreach($items as $item) {{$item->price}}<br /> @endforeach </td> <td> @foreach($items as $item) <img src="{{$item->gazou}}"><br /> @endforeach </td> </tr> </table> <br /> <input type = "submit" value="削除" id = "id"> <script> var btn = document.getElementById('id'); btn.addEventListener('click',function() { window.confirm('本当に削除しますか?'); }) </script> </form> <button onclick="history.back()">戻る</button> <a href="/top">業務管理システム</a> </body> </html>
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。