Laravel5.2でアドミンと一般ユーザーを別テーブルで管理するマルチ認証を実装しています。
5.1とはミドルウェア周りが少し変わったようで戸惑っています。
以下のような設定で意図する動作はできているのですが、ミドルウェアの設定に問題がないか不安です。
Ex.アドミンとユーザーでログアウトする際のミドルウェアの設定が異なっているなど。
※パスワードリセットの機能についてはユーザー側のみ実装しています。
聞きたいこと
- ルーティング・ミドルウェアまわりの改善策(こうした方が綺麗にかけるなど)
- ミドルウェアのwebとはそもそも何なのでしょうか・・・?
php
1 2routes.php 3 4<?php 5 6//=============================== 7// Applications 8//=============================== 9 //------------------------------- 10 // AdminPages 11 //------------------------------- 12 Route::group(['middleware' => 'guest:admin'], function () { 13 Route::get('/admin/login', 'AdminAuth\AdminAuthController@showLoginForm'); 14 Route::post('/admin/login', 'AdminAuth\AdminAuthController@login'); 15 }); 16 17 Route::group(['middleware' => 'auth:admin'], function () { 18 Route::get('/adminpage', 'Admin\AdminPageController@getAdminPage'); 19 20 // ここにアドミン用ページを追加していく 21 22 Route::get('/admin/logout', 'AdminAuth\AdminAuthController@logout'); 23 }); 24 25 26 //------------------------------- 27 // UserPages 28 //------------------------------- 29 Route::auth(); 30 31 Route:: group(['middleware' => 'auth:users'], function() { 32 Route::get('/mypage', 'User\MyPageController@getMyPage'); 33 34 // ここにユーザー用ページを追加していく 35 36 }); 37 38 39 40//=============================== 41// Pages - No need to authenticate 42//=============================== 43Route::get('/', 'Page\PageController@getTop'); 44Route::get('/contact', 'Page\PageController@getContact');
php
1 2auth.php 3 4<?php 5 6return [ 7 'defaults' => [ 8 'guard' => 'users', 9 'passwords' => 'users', 10 ], 11 'guards' => [ 12 'web' => [ 13 'driver' => 'session', 14 'provider' => 'users', 15 ], 16 'users' => [ 17 'driver' => 'session', 18 'provider' => 'users', 19 ], 20 'admin' => [ 21 'driver' => 'session', 22 'provider' => 'admin', 23 ], 24 ], 25 'providers' => [ 26 'users' => [ 27 'driver' => 'eloquent', 28 'model' => App\Models\User::class, 29 ], 30 'admin' => [ 31 'driver' => 'eloquent', 32 'model' => App\Models\Admin::class, 33 ], 34 ], 35 'passwords' => [ 36 'users' => [ 37 'provider' => 'users', 38 'email' => 'auth.emails.password', 39 'table' => 'password_resets', 40 'expire' => 60, 41 ], 42 ], 43]; 44
ルーティング +--------+----------+-------------------------+------+------------------------------------------------------------------+-----------------------------+ | Domain | Method | URI | Name | Action | Middleware | +--------+----------+-------------------------+------+------------------------------------------------------------------+-----------------------------+ | | GET|HEAD | / | | App\Http\Controllers\Page\PageController@getTop | web | | | GET|HEAD | admin/login | | App\Http\Controllers\AdminAuth\AdminAuthController@showLoginForm | web,guest:admin,guest:admin | | | POST | admin/login | | App\Http\Controllers\AdminAuth\AdminAuthController@login | web,guest:admin,guest:admin | | | GET|HEAD | admin/logout | | App\Http\Controllers\AdminAuth\AdminAuthController@logout | web,auth:admin | | | GET|HEAD | adminpage | | App\Http\Controllers\Admin\AdminPageController@getAdminPage | web,auth:admin | | | GET|HEAD | contact | | App\Http\Controllers\Page\PageController@getContact | web | | | POST | login | | App\Http\Controllers\Auth\AuthController@login | web,guest:users | | | GET|HEAD | login | | App\Http\Controllers\Auth\AuthController@showLoginForm | web,guest:users | | | GET|HEAD | logout | | App\Http\Controllers\Auth\AuthController@logout | web | | | GET|HEAD | mypage | | App\Http\Controllers\User\MyPageController@getMyPage | web,auth:users,auth | | | POST | password/email | | App\Http\Controllers\Auth\PasswordController@sendResetLinkEmail | web,guest | | | POST | password/reset | | App\Http\Controllers\Auth\PasswordController@reset | web,guest | | | GET|HEAD | password/reset/{token?} | | App\Http\Controllers\Auth\PasswordController@showResetForm | web,guest | | | GET|HEAD | register | | App\Http\Controllers\Auth\AuthController@showRegistrationForm | web,guest:users | | | POST | register | | App\Http\Controllers\Auth\AuthController@register | web,guest:users | +--------+----------+-------------------------+------+------------------------------------------------------------------+-----------------------------+
あなたの回答
tips
プレビュー