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

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

新規登録して質問してみよう
ただいま回答率
85.42%
Livewire

Livewireは、JavaScriptを記述することなくPHPのみで動的コンポーネントを作成できるライブラリです。Bladeの構文をそのまま使用できるため、Laravelとの相性が良く、Vue.jsやReactよりシンプルに扱うことができます。

Laravel

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

Q&A

解決済

1回答

4542閲覧

laravel8 ユーザー権限ごとにログイン後のリダイレクト先変更について

yuuu752

総合スコア18

Livewire

Livewireは、JavaScriptを記述することなくPHPのみで動的コンポーネントを作成できるライブラリです。Bladeの構文をそのまま使用できるため、Laravelとの相性が良く、Vue.jsやReactよりシンプルに扱うことができます。

Laravel

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

0グッド

0クリップ

投稿2021/08/01 10:48

編集2021/08/01 10:50

前提・実現したいこと

利用者と管理者をログイン時にロールで認可して、ユーザー権限ごとにリダイレクト先を変更したい。

発生している問題・エラーメッセージ

該当コードのように実装し、利用者の方は想定通りリダイレクトされるが、管理者の方がエラーが出てしまう。

403 THIS ACTION IS UNAUTHORIZED.

怪しい点があればご指摘頂ければと思います。
よろしくお願い致します。

該当のソースコード

/providers/AuthServiceProvider <?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\Models\Model' => 'App\Policies\ModelPolicy', ]; /** * Register any authentication / authorization services. * * @return void */ public function boot() { $this->registerPolicies(); // 管理者以上(管理者&システム管理者、ロール1〜10以下)に許可 Gate::define('admin-higher', function ($user) { return ($user->role >= 1 && $user->role <= 10); }); // 一般ユーザ以上に許可(ロール11〜100以下) Gate::define('user-higher', function ($user) { return ($user->role > 10 && $user->role <= 100); }); } }
/Middleware/RedirectIfAuthenticated.php <?php namespace App\Http\Middleware; use App\Providers\RouteServiceProvider; use Closure; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class RedirectIfAuthenticated { public function handle(Request $request, Closure $next, ...$guards) { $guards = empty($guards) ? [null] : $guards; foreach ($guards as $guard) { if ($guard == "admin-higher" && Auth::guard($guard)->check()) { return redirect()->route('admin-home'); } if ($guard == "user-higher" && Auth::guard($guard)->check()) { return redirect()->route('home'); } } return $next($request); } }
/config/web.php // 利用者権限 Route::group(['middleware' => ['auth', 'can:user-higher']], function () { //在庫一覧 Route::get('list', [StockController::class, 'index'])->name('home'); // 管理者以上 Route::group(['middleware' => ['auth', 'can:admin-higher']], function () { // 在庫一覧 Route::get('admin/list', [AdminController::class, 'index'])->name('admin-home');
//利用者側 class StockController extends Controller { public function __construct() { // __construct クラスを追加 $this->middleware('auth'); // ログイン者のみ下記メソッドを実行可能に } public function index(Request $request) { $user_id = Auth::id(); //ログインユーザーのID取得 $stocks = Stock::with('user')->where('user_id', '=', $user_id)->simplePaginate(8); return view('stock.list', ['stocks' => $stocks]); }
//管理者側 class AdminController extends Controller { public function index(Request $request) { $stocks = Stock::query()->simplePaginate(8); //全在庫取得 return view('stock.list', ['stocks' => $stocks]); }

ログイン者のロール情報
・利用者 ロール→11
・管理者 ロール→2

試したこと

リダイレクト先の記述を下記のように変更

/Middleware/RedirectIfAuthenticated.php <?php namespace App\Http\Middleware; use App\Providers\RouteServiceProvider; use Closure; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class RedirectIfAuthenticated { public function handle(Request $request, Closure $next, ...$guards) { $guards = empty($guards) ? [null] : $guards; foreach ($guards as $guard) { if ($guard == "admin-higher" && Auth::guard($guard)->check()) { return redirect()->route('admin-home'); }elseif ($guard == "user-higher" && Auth::guard($guard)->check()) { return redirect()->route('home'); } } return $next($request); } }

補足情報(FW/ツールのバージョンなど)

laravel8、livewire

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

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

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

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

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

guest

回答1

0

自己解決

こちら解決しましたので質問を閉じさせてもらいます。
解決方法については下記のQiitaにてご紹介してますので、同じことで悩まれてる方は参考にしてみてください。
Qiita

投稿2021/08/10 14:05

yuuu752

総合スコア18

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.42%

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

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

質問する

関連した質問