掌田津耶乃氏著の"PHPフレームワークLaravel入門"の本を参考に、Laravelで、webアプリを作っています。
LaravelのversionとしてはLaravel Framework 8.27.0を使っています。
Userとしてログインし、情報を入力して、それをBoardに保存して、検索によって、そのBoardの情報を取り出すことができる様なアプリを作ろうとしております。
UserとBoardの情報が結びついていることがわかる様に、withによるEagerローディングを使って、検索結果のBoardの情報の隣にUserのnameを表示できる様にはできました。
このUser情報と結びついた、特定のBoardを、/helloにおいて、whereを用いた条件付き検索で取り出せる様にしたいのですが、上手くいきません。
Models↓
User
1<?php 2 3namespace App\Models; 4 5use Illuminate\Contracts\Auth\MustVerifyEmail; 6use Illuminate\Database\Eloquent\Factories\HasFactory; 7use Illuminate\Foundation\Auth\User as Authenticatable; 8use Illuminate\Notifications\Notifiable; 9 10class User extends Authenticatable 11{ 12 use HasFactory, Notifiable; 13 14 /** 15 * The attributes that are mass assignable. 16 * 17 * @var array 18 */ 19 protected $fillable = [ 20 'name', 'email', 'password', 21 ]; 22 23 /** 24 * The attributes that should be hidden for arrays. 25 * 26 * @var array 27 */ 28 protected $hidden = [ 29 'password', 'remember_token', 30 ]; 31 32 /** 33 * The attributes that should be cast to native types. 34 * 35 * @var array 36 */ 37 protected $casts = [ 38 'email_verified_at' => 'datetime', 39 ]; 40 41 protected $guarded = array('id'); 42 43 public function boards() 44 { 45 return $this->hasMany('App\Models\Board'); 46 } 47}
Board
1<?php 2 3namespace App\Models; 4 5use Illuminate\Database\Eloquent\Factories\HasFactory; 6use Illuminate\Database\Eloquent\Model; 7 8class Board extends Model 9{ 10 protected $guarded = array('id'); 11 12 public static $rules = array( 13 'info_1' => 'required', 14 'info_2' => 'required', 15 'info_3' => 'required', 16 'info_4' => 'required', 17//理由があってinfo_5はrequiredではありません。 18 ); 19 20 public function user() 21 { 22 return $this->belongsTo('App\Models\User'); 23 } 24 25 public function getData() 26 { 27 return $this->info_1 . $this->info_2 . $this->info_3 . $this->info_4 . $this->info_5; 28 } 29}
View↓
(hello側のindex.blade.phpの@section('content')ディレクティブ(検索用))
index
1@if(isset($items)) 2 @section('content') 3 <div class="container"> 4 <table> 5 <tr><th>Circle_Information</th><th>User</th></tr> 6 @foreach ($items as $item) 7 <tr> 8 <td>{{$item->getData()}}</td> 9 <td>{{$item->user->name}}</td> 10 </tr> 11 @endforeach 12 </table> 13 </div> 14 @endsection 15@else 16 @section('content') 17 <div class="container"> 18 <form action="/hello" method="post"> 19 {{ csrf_field() }} 20 <div class="forms"> 21 <label class="form-tag"> 22 <input type="text" name="info_1"> 23 </label> 24 <label class="form-tag"> 25 <input type="text" name="info_2"> 26 </label> 27 <label class="form-tag"> 28 <input type="text" name="info_3"> 29 </label> 30 <label class="form-tag"> 31 <input type="text" name="info_4"> 32 </label> 33 <label class="form-tag"> 34 <input type="date" name="info_5"> 35 </label> 36 <label class="form-tag"> 37 <input type="submit" value="検索する"> 38 </label> 39 </div> 40 </form> 41 </div> 42 @endsection 43@endif
(board側のindex.blade.phpの@section('content')ディレクティブ(表示用))
index
1@section('content') 2<div class="container"> 3 <table> 4 <tr><th>Information</th><th>User</th></tr> 5 @foreach ($items as $item) 6 <tr> 7 <td>{{$item->getData()}}</td> 8 <td>{{$item->user->name}}</td> 9 </tr> 10 @endforeach 11 </table> 12</div> 13@endsection
(board側のadd.blade.phpの@section('content')ディレクティブ(入力用))
add
1@section('content') 2<div class="container"> 3 <table> 4 <form action="/board/add" method="post"> 5 {{ csrf_field() }} 6 <div class="a_form"> 7 <label>info_1 : </label> 8 <input type="text" name="info_1"> 9 </div> 10 <div class="a_form"> 11 <label>info_2 : </label> 12 <input type="text" name="info_2"> 13 </div> 14 <div class="a_form"> 15 <label>info_3 : </label> 16 <input type="text" name="info_3"> 17 </div> 18 <div class="a_form"> 19 <label>info_4 : </label> 20 <input type="text" name="info_4"> 21 </div> 22 <div class="a_form"> 23 <label>info_5 : </label> 24 <input type="text" name="info_5"> 25 </div> 26 <div class="a_form"> 27 <input type="submit" value="送信する"> 28 </div> 29 </form> 30 </table> 31</div> 32@endsection
Controller↓
HelloController
1class HelloController extends Controller 2{ 3 4 public function index(Request $request) 5 { 6 $user = Auth::user(); 7 $param = ['user' => $user]; 8 return view('hello/index', $param); 9 } 10 11 public function post(Request $request) 12 { 13 $user = Auth::user(); 14 $items = Board::with('user')->where('info_1', '%' . $request->info_1 . '%') 15 ->where('info_2', '%' . $request->info_2 . '%') 16 ->where('info_3', '%' . $request->info_3 . '%') 17 ->where('info_4', '%' . $request->info_4 . '%') 18 ->where('info_5', '%' . $request->info_5 . '%') 19 ->get(); 20 $param = [ 21 'info_1' => $request->info_1, 22 'info_2' => $request->info_2, 23 'info_3' => $request->info_3, 24 'info_4' => $request->info_4, 25 'info_5' => $request->info_5, 26 'user' => $user, 27 'items' => $items, 28 ]; 29 return view('hello/index', $param); 30 } 31}
BoardController
1<?php 2 3namespace App\Http\Controllers; 4 5use App\Models\Board; 6use Illuminate\Http\Request; 7use Illuminate\Support\Facades\Auth; 8 9class BoardController extends Controller 10{ 11 public function index(Request $request) 12 { 13 $user = Auth::user(); 14 $items = Board::with('user')->get(); 15 $param = [ 16 'user' => $user, 17 'items' => $items, 18 ]; 19 return view('board/index', $param); 20 } 21 22 public function add(Request $request) 23 { 24 $user = Auth::user(); 25 $param = ['user' => $user]; 26 return view('board/add', $param); 27 } 28 29 public function create(Request $request) 30 { 31 $this->validate($request, Board::$rules); 32 $board = new Board; 33 $board->user_id = Auth::id(); 34 $form = $request->all(); 35 unset($form['_token']); 36 $board->fill($form)->save(); 37 return redirect('/board'); 38 } 39}
routes > web.php↓
web
1<?php 2 3use Illuminate\Support\Facades\Route; 4use App\Http\Middleware\HelloMiddleware; 5 6 7Route::get('/', function () { 8 return view('welcome'); 9}); 10 11Route::get('hello', 'App\Http\Controllers\HelloController@index'); 12Route::post('hello', 'App\Http\Controllers\HelloController@post'); 13 14Route::get('board', 'App\Http\Controllers\BoardController@index'); 15 16Route::get('board/add', 'App\Http\Controllers\BoardController@add'); 17Route::post('board/add', 'App\Http\Controllers\BoardController@create');
/helloで検索しても欲しい情報が出てこないのはどうしてなのでしょうか?
/boardに直接アクセスすると入力した全てのテーブルは表示されるのですが。。。
どなたかわかる方がいらっしゃれば、ご教授お願い致します。
回答1件
あなたの回答
tips
プレビュー