🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Q&A

解決済

1回答

1666閲覧

Laravel 7.x ログイン時にリレーション先のカラムを参照して、リダイレクト先を割り振りたい

youth_k0228

総合スコア18

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

0グッド

0クリップ

投稿2021/02/15 06:44

編集2021/02/15 07:23

こんにちは。
Laravel7系を使い、Usersテーブルとは別のテーブルにあるフラグを読み取って一般ユーザー用と管理者用のトップページに割り振りたいと考えています。
Gateを用いて、usersテーブルの「role_name」で割り振ることは出来ましたが、リレーション先であるrolesテーブルの「flag」で割り振る方法を調べましたが、単一のテーブルでのログイン機能実装方法や、usersテーブルとは別で管理者用の同等のテーブルを用意する等、該当のものや近い方法を見つけることが出来ませんでした。
方法としては、ログインのリクエスト情報を取得する際にrolesテーブルを参照し、権限を持っているかどうかで条件分岐するのかなと考えています。
拙い質問で大変申し訳ございませんが、取得したログイン情報からリレーション先のテーブルを参照して判別する方法、又はログイン時におけるログインリクエストの取得方法についてご助言頂きたいと思います。
宜しくお願い致します。

#実現したいこと
①メールアドレスとパスワードでログイン
②ログインのリクエスト情報から、usersの「role_name」を取得する
③取得した「role_name」と同じ所属名をrolesテーブルで探す
④該当の所属名の「flag」を確認し、「1」の場合は管理者用ページに、「0」の場合は一般ユーザー用ページリダイレクトする

#テーブル
######usersテーブル
|id|name|email|role_name|
|:--|:--:|:--:|
|1|テスト|test@test.com|管理者|

#rolesテーブル

idnameflag
1管理者1
2一般0
#ソースコード
######User.php
```php
<?php namespace App; use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; class User extends Authenticatable { use Notifiable; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'code','name', 'email', 'password','role_name', ]; /** * 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', ]; public function role() { //所属はRolesテーブルを参照する return $this->belongsTo('App\Role','name'); } } ``` ######Role.php ```php <?php namespace App; use Illuminate\Database\Eloquent\Model; class Role extends Model { //所属テーブルから取得させる protected $fillable = [ 'id','name' ]; public function users() { return $this->hasMany('App\User'); } } ``` ######AuthServiceProvider.php ```php <?php namespace App\Providers; use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider; use Illuminate\Support\Facades\Gate; class AuthServiceProvider extends ServiceProvider { /** * The policy mappings for the application. * * @var array */ protected $policies = [ // 'App\Model' => 'App\Policies\ModelPolicy', ]; /** * Register any authentication / authorization services. * * @return void */ public function boot() { $this->registerPolicies(); //管理者のみアクセスを許可 Gate::define('admin',function($user){ return ($user->role_name='管理者'); }); } } ``` ######LoginController.php ```php <?php namespace App\Http\Controllers\Auth; use App\Http\Controllers\Controller; use App\Providers\RouteServiceProvider; use Illuminate\Foundation\Auth\AuthenticatesUsers; use Illuminate\Support\Facades\Auth; use App\Role; use App\User; class LoginController extends Controller { /* |-------------------------------------------------------------------------- | Login Controller |-------------------------------------------------------------------------- | | This controller handles authenticating users for the application and | redirecting them to your home screen. The controller uses a trait | to conveniently provide its functionality to your applications. | */ use AuthenticatesUsers; /** * Where to redirect users after login. * * @var string */ protected $redirectTo = RouteServiceProvider::HOME; protected function authenticated(\Illuminate\Http\Request $request, $user) { $roleCh=$this->guard()->user()->role_name; if($roleCh='管理者'){ return view('admin.top'); }else{ return view('user.top'); } } /** * Create a new controller instance. * * @return void */ public function __construct() { $this->middleware('guest')->except('logout'); } } //select * from users inner join roles on users.role_name = roles.name ```

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

phper.k

2021/02/15 08:22

リレーション定義おかしいと思うんですけど??
youth_k0228

2021/02/15 08:30

お世話になります。 「ユーザーはは一つの所属しかないが、一つの所属に対して複数のユーザーがいる」と考えリレーションを設定しましたが、具体的に「おかしい」と感じた部分をご教示頂けないでしょうか。
phper.k

2021/02/15 08:34 編集

users テーブルにあるカラム、role_name じゃなくて role_id じゃないといけないし、 public function role() { //所属はRolesテーブルを参照する return $this->belongsTo('App\Role'); } になるはずです。 表題の問題以前の、前提が正しくないです。
youth_k0228

2021/02/15 08:51

すみません。 「name」と「id」の違いは何でしょうか。 「name」は一意性を持っていないから、指定することは出来ない ということでしょうか。
phper.k

2021/02/15 08:54

DBのリレーションって常識的にIDで連結するものです。 これはLaravelに限ったことではありません。
youth_k0228

2021/02/15 09:28

大変失礼致しました。 こちらにつきまして存じ上げていませんでした。
guest

回答1

0

自己解決

usersテーブルの「role_name」を「role_id」にカラム名を変更し、rolesの「id」を参照するようにしました。
又、Gateでの参照方法を以下のように記述しました。

php

1Gate::define('admin', function ($user) { 2 return $user->role->flag; 3

ログイン時にリレーションが上手くいかずnullになってしまった原因は、「id」以外のカラムを外部キーとして指定しなかったにも関わらず、「belongsTo」の第二引数として「id」ではないカラムを指定しなかったことと、Gateでのrolesテーブルの参照方法が誤っていたことでした。

投稿2021/02/16 09:25

youth_k0228

総合スコア18

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問