質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.45%

  • PHP

    24625questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • Laravel 5

    2643questions

    Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

  • PostgreSQL

    1397questions

    PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

user_idが一致するもののみ表示させたい

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 160

reina0609

score 3

閲覧いただきありがとうございます。

データベースから、user_idが特定のもののみ、表示させたいです。

例えば、ログインしたユーザーが、user_id=1ならば、そのデータのみ表示させるマイページ画面を表示させるものです。

現在、user_idは取得できているのですが、それに一致したデータが表示されず、マイページをクリックすると、not found が表示されてしまい困っています。

よろしくお願いします。

web.php

Route::group(['middleware' => 'auth'],function(){

    Route::get('/users/{user_id}/plans', 'HomeController@index')->name('home');/こちらを使ってマイページを表示させたいです/

    Route::get('/plans/create', 'PlanController@showCreateForm')->name('plans.create');
    Route::post('/plans/create', 'PlanController@create');

    Route::get('/users/{user_id}/plans/{p_id}/edit', 'PlanController@showEditForm')->name('plans.edit');
    Route::post('/users/{user_id}/plans/{p_id}/edit', 'PlanController@edit');

});

Auth::routes();

Route::get('/plans', 'PlanController@index')->name('plans.index');

Homecontroller.php

public function index()
    {
        $user_id = Auth::id();

        $plans = Plan::where('user_id',$user_id)->select('title','image');

        return view('home',[
            'user_id' => $user_id,
            'plans' => $plans,
        ]);
    }


layout.blade.php

<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Travel</title>
    @yield('styles')
    <link rel="stylesheet" href="/css/styles.css">
</head>
<body>
<header>
    <nav class="my-navbar">
        <a class="my-navbar-brand" href="{{ route('plans.index') }}">Travel</a>
        <div class="my-navbar-control">
            @if(Auth::check()) /ここのマイページから、目的のマイページに遷移/
                <a href=“{{ route('home', ['user_id' => Auth::id()]) }}” id=“mypage” class=“my-navbar-item”>マイページ</a><a href="#" id="logout" class="my-navbar-item">ログアウト</a>
                <form id="logout-form" action="{{ route('logout') }}" method="POST" style="display: none;">
                    @csrf
                </form>
            @else
                <a class="my-navbar-item" href="{{ route('login') }}">ログイン</a><a class="my-navbar-item" href="{{ route('register') }}">会員登録</a>
            @endif
        </div>
    </nav>
</header>
<main>
    @yield('content')
</main>
@if(Auth::check())
    <script>
        document.getElementById('logout').addEventListener('click', function(event) {
            event.preventDefault();
            document.getElementById('logout-form').submit();
        });
    </script>
@endif
@yield('scripts')
</body>
</html>

home.blade.php

@extends('layout')

@section('content')
    <div class="container">
        <div class="row">
            <div class="col col-md-offset-3 col-md-6">
                <nav class="panel panel-default">
                    <div class="panel-heading">
                        登録プラン一覧
                    </div>
                    <div class="panel-body">
                        <div class="text-center">
                            <div>
                                @foreach ($plans as $plan)
                                    <div class="list-group-item">
                                        {{ $plan->title }} <br >
                                        {{ $plan->image }}
                                    </div>
                                @endforeach
                            </div>
                        </div>
                    </div>
                </nav>
            </div>
        </div>
    </div>
@endsection

DBの取得したい情報です。
イメージ説明

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • reina0609

    2019/06/12 15:10 編集

    エラーとしては、
    local.ERROR: Route [/users/{user_id}/plans] not defined. (View: /var/www/resources/views/layout.blade.php) (View: /var/www/resources/views/layout.blade.php) {"userId":1,"exception":"[object] (ErrorException(code: 0): Route [/users/{user_id}/plans] not defined. (View: /var/www/resources/views/layout.blade.php) (View: /var/www/resources/views/layout.blade.php) at /var/www/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php:388, ErrorException(code: 0): Route [/users/{user_id}/plans] not defined. (View: /var/www/resources/views/layout.blade.php) at /var/www/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php:388, InvalidArgumentException(code: 0): Route [/users/{user_id}/plans] not defined. at /var/www/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php:388)
    [stacktrace]
    と出ています。

    layout.php の<a href=“{{ route('home', ['user_id' => Auth::id()]) }}” id=“mypage” class=“my-navbar-item”>マイページ</a> をクリックした際、 not found と表示されます。

    index()にて取得した$postsのdump()の結果と、blade側でのdump()の結果なのですが、
    index()にて取得した$postsのdump()の結果はnot foundとなってしまうため、確認方法がわかりませんでした。
    blade側でのdump()の結果は['user_id' => Auth::id()]から、1となっております。

    キャンセル

  • hentaiman

    2019/06/12 16:00

    エラーログまで確認しててroute not definedって出てるんならとりあえずroute listでルーティング情報確認してみては?

    キャンセル

  • reina0609

    2019/06/12 16:30

    ルーティングを確認してみましたが、
    GET|HEAD | users/{user_id}/plans | home | App\Http\Controllers\HomeController@index | web,auth
    となっており、正しくできているようでした。

    キャンセル

回答 4

+2

Laravel的には、ルートモデルバインディングの暗黙の結合を使った方が良い気がします。

Laravel 5.8 ルーティングモデル結合ルート 暗黙の結合

Route::group(['middleware' => 'auth'],function(){

    Route::get('/users/{user}/plans', 'HomeController@index')->name('home');
});
public function index(User $user)
{

    $plans = Plan::where('user_id',$user->id)->select('title','image');

    return view('home',[
        'user_id' => $user->id,
        'plans' => $plans,
    ]);
}
<a href={{ route('home', ['user' => Auth::user()]) }}id=“mypage” class=“my-navbar-item”>マイページ</a>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/06/13 14:41

    コメントありがとうございます!「暗黙の結合」読みましたが、まさしくこの、「一致するモデルインスタンスがデータベースへ存在しない場合、404 HTTPレスポンスが自動的に生成されます。」という部分でnot foundが出ていると思われます!
    回答いただいた通り、修正してみたのですが、やはり、not found が出てしまい、原因は「一致するモデルインスタンスがデータベースへ存在しない」ことであると考え、
    モデルApp\Userのモデルに
    protected $fillable = [
    'name', 'email', 'password','id',
    ];
    とし、web.phpを
    Route::get('/users/{user}/plans',function(App\User $user){
    return $user->id;
    },'HomeController@index')->name('home');
    としてみたのですが、やはりnot found と出てしまいました。他に対処法はありますでしょうか?

    キャンセル

  • 2019/06/13 15:16

    なるほど
    user引数のidを実際にあるUserデータのidにしてみるとどうでしょうか(ここではid 1があるとして)
    <a href=“{{ route('home', ['user' =>1]) }}” id=“mypage” class=“my-navbar-item”>マイページ</a>

    キャンセル

  • 2019/06/13 15:16

    あと、artisan make:authで作成される、デフォルトのhome用ルートはコメントアウトや削除しているでしょうかも確認してみてください。

    キャンセル

  • 2019/06/13 15:32

    id=1の場合も not found となりました。(Auth::user()の場合でも、URLから、idは取得できているようです)home用のルートは、ControllerのAuth、Middleware全て書き換え済みです。

    ルートを再度確認したのですが、
    GET|HEAD | users/{user}/plans | home | Closure
    となっており、
    Route::get('/users/{user}/plans',function(App\User $user){
    return $user->id;
    },'HomeController@index')->name('home');
    では、ルーティングがうまくいっていないようでした。この書き方は正しくないのでしょうか?

    キャンセル

  • 2019/06/13 15:58

    うーん、難しいですね。
    Not Foundになる、URLは (アプリの基本URL)/users/1/plans にきちんとなっていますか?

    また、App\Userのタイプヒントを消して、以下にすると単に1が表示されるでしょうか
    Route::get('/users/{user}/plans',function($user){
    return $user;
    },'HomeController@index')->name('home');

    キャンセル

check解決した方法

0

0
こちら解決しました。
原因は、

<a href="{{ route('mypage') }}">

としていたためでした。ダブルクォーテーションいらず、

<a href={{ route('mypage') }}>

として、not foundは出なくなりました!
回答いただきありがとうございました。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

ルーティングで定義したパラメータをコントローラで受け取って利用してみては。

Route::get('/users/{user_id}/plans', 'HomeController@index')->name('home')


なので、例えばこう

    public function index($user_id)
    {
        $plans = Plan::where('user_id',$user_id)->select('title','image');

        return view('home',[
            'user_id' => $user_id,
            'plans' => $plans,
        ]);
    }

ただ、もし「ログイン者のみ情報を見ることができる」のでしたらそもそもルーティングにuser_idは不要に思いますが、そこは仕様次第です。
※誰でも見れるのでしたらidよりもteratailのようにユーザー名のほうが良いです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/06/12 16:29

    回答ありがとうございます。回答いただいた通り、修正してみたのすが、やはり、同様にlayout.php の<a href=“{{ route('home', ['user_id' => Auth::id()]) }}” id=“mypage” class=“my-navbar-item”>マイページ</a> をクリックした際、 not found と表示されてしまいました。
    よろしければ、他に考えられる原因を教えていただけますでしょうか?

    キャンセル

  • 2019/06/12 16:36

    hrefの設定値はどうなっていますか?
    ブラウザ「ソースを表示」から確認してみてください。

    キャンセル

0

こちら解決しました。
原因は、

<a href="{{ route('mypage') }}">


としていたためでした。ダブルクォーテーションいらず、

<a href={{ route('mypage') }}>


として、not foundは出なくなりました!
回答いただきありがとうございました。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.45%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • PHP

    24625questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • Laravel 5

    2643questions

    Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

  • PostgreSQL

    1397questions

    PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。