前提・実現したいこと
現在,PHP/laravelを使ったポートフォリオを作成し、投稿者名を表示させるつもりですがうまく取得できない状況です。
発生している問題・エラーメッセージ
$post->user_idと記述した場合は下記画像のようにid(1)は取得できます。
![
$post->user_nameと記述した場合は下記画像のように何も表示されません。
該当のソースコード
index.blade.php @component('components.header') @endcomponent <main> <section class="py-5 text-center container"> <div class="row py-lg-5"> <div class="col-lg-6 col-md-8 mx-auto"> <h1 class="fw-light">News</h1> <p class="lead text-muted">最近あった出来事を共有するサービスです!</p> </div> </div> </section> <h1 style="text-align: center;">新着投稿</h1> @include('posts/search') <div class="album py-5 bg-light"> <div class="container"> <div class="row row-cols-1 row-cols-sm-2 row-cols-md-3 g-3"> @foreach ($posts as $post) <div class="col"> <div class="card shadow-sm"> <svg class="bd-placeholder-img card-img-top" width="100%" height="225" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="Placeholder: Thumbnail" preserveAspectRatio="xMidYMid slice" focusable="false"><title>Placeholder</title><rect width="100%" height="100%" fill="#55595c"/><text x="50%" y="50%" fill="#eceeef" dy=".3em">Thumbnail</text></svg> <div class="card-body"> <a class="card-text" href="{{ route("post.show", ["id" => $post->id]) }}">{{ $post->title }}</a> <div class="d-flex justify-content-between align-items-center"> <div class="btn-group"> <small class="text-muted">{{ $post->created_at }}</small> </div> <small class="text-muted">{{ $post->user_id }}</small> </div> </div> </div> </div> @endforeach </div> </div> </div> </div> </main>
Post.php <?php namespace App; use Illuminate\Database\Eloquent\Model; class Post extends Model { /** * リレーション (従属の関係) * * @return \Illuminate\Database\Eloquent\Relations\BelongsTo */ public function user() { return $this->belongsTo('app\User'); } }
User.php <?php namespace App; use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; class User extends Authenticatable { /** * リレーション (1対多の関係) * * @return \Illuminate\Database\Eloquent\Relations\HasMany */ public function posts() { return $this->hasMany('app\Post'); } use Notifiable; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'name', 'email', 'password', ]; /** * The attributes that should be hidden for arrays. * * @var array */ protected $hidden = [ 'password', 'remember_token', ]; /** * The attributes that should be cast to native types. * * @var array */ protected $casts = [ 'email_verified_at' => 'datetime', ]; }
PostController.php <?php namespace App\Http\Controllers; use App\User; use App\Post; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class PostController extends Controller { public function __construct() { $this->middleware('auth')->except(['index']); } /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index(Request $request) { if ($request->filled('keyword')) { $keyword = $request->input('keyword'); $posts = Post::where('title', 'like', '%'.$keyword.'%')->get(); }else{ $posts = Post::latest()->get(); } return view('posts/index', ['posts' => $posts]); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create(Request $request){ $user_id = Auth::id(); $message = '投稿フォーム: '; return view('posts/new', ['message'=>$message]); } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $post = new Post(); $post->user_id = $request->user()->id; $post->title = $request->title; $post->text = $request->text; $post->save(); return redirect('/'); } /** * Display the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function show(Request $request, $id, Post $post){ $post = Post::find($id); // モデルから指定データ取得 return view('posts/show', ['post' => $post]); } /** * Show the form for editing the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function edit(Request $request, $id, Post $post) { $post = Post::find($id); return view('posts/edit', ['post'=>$post]); } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request, $id, Post $post) { $post = Post::find($id); $post->title = $request->title; $post->text = $request->text; $post->save(); return redirect()->route('post.show', ['id' => $post->id]); } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\Response */ public function destroy(Request $request, $id, Post $post) { $post = Post::find($id); $post->delete(); return redirect('/'); } }
試したこと
postのマイグレーションファイルにuser情報の外部キーの設定がないことを確認。
以下のように記述した。
2021_04_30_221633_create_posts_table.php <?php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; class CreatePostsTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::create('posts', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('title'); $table->text('text'); $table->unsignedBigInteger('user_id'); $table->foreign('user_id')->references('id')->on('users'); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('posts'); } }
外部キーの設定を行なったものの改善されなかった。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/05/07 04:52