Laravel 5.2 新特性系列 —— 多用戶認證功能實現(xiàn)詳解帕棉。

Laravel 5.2 新特性系列 —— 多用戶認證功能實現(xiàn)詳解


Laravel 5.2新增多用戶認證支持针肥,即同時允許不同數(shù)據(jù)表用戶(如前臺用戶、后臺用戶)登錄認證香伴。下面我們就來簡單介紹多用戶登錄及注冊功能實現(xiàn)慰枕。

1 生成認證腳手架

首先我們使用Laravel 5.2提供的認證腳手架完成初始化工作:

php artisan make:auth

該Artisan命令會生成用戶認證所需的路由、視圖以及HomeController:

去查看路由文件routes.php即纲,會發(fā)現(xiàn)該文件已經(jīng)被更新:

Route::group(['middleware' => 'web'], function () {
    Route::auth();
    Route::get('/home', 'HomeController@index');
});

其中Route::auth()定義了注冊登錄路由具帮,/home為認證通過后跳轉(zhuǎn)路由。

2 實現(xiàn)前臺用戶登錄

接下來我們先實現(xiàn)前臺用戶登錄,也就是Laravel自帶的User用戶登錄蜂厅。通過上面的腳手架匪凡,我們已經(jīng)生成了認證所需的所有代碼,剩下要做的就是使用遷移命令創(chuàng)建用戶認證相關(guān)表:

php artisan migrate

該命令執(zhí)行后生成users表和password_resets表掘猿,分別為用戶主表和密碼重置表锹雏。

然后我們就可以在瀏覽器中輸入 http://laravel.app/register 來注冊新用戶。

3 編輯認證配置文件

要實現(xiàn)多用戶認證术奖,首先要配置認證配置文件auth.php礁遵,這里我們實現(xiàn)的功能是前后臺用戶登錄,所以對應配置如下:

<?php

return [

    'defaults' => [
        'guard' => 'web',
        'passwords' => 'users',
    ],

    'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
        'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],
        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    ],

    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],
        'admins' => [
            'driver' => 'eloquent',
            'model' => App\Admin::class,
        ],
    ],

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'email' => 'auth.emails.password',
            'table' => 'password_resets',
           'expire' => 60,
        ],
    ],
];

認證是由guard和provider兩部分構(gòu)成的采记,所以我們在這兩個配置項中分別新增了admin和admins選項佣耐。

4 創(chuàng)建后臺用戶模型

接下來我們來實現(xiàn)后臺用戶登錄,首先使用如下Artisan命令生成后臺用戶模型:

php artisan make:model Admin --migration

帶上--migration選項會生成對應用戶表admins唧龄,我們定義該數(shù)據(jù)表字段和users一樣:

Schema::create('admins', function (Blueprint $table) {
    $table->increments('id');
    $table->string('name');
    $table->string('email')->unique();
    $table->string('password', 60);
    $table->rememberToken();
    $table->timestamps();
});

然后通過運行遷移命令生成該表:

php artisan migrate

然后更新Admin模型類如下:

<?php

namespace App;

use Illuminate\Foundation\Auth\User as Authenticatable;

class Admin extends Authenticatable
{
    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'name', 'email', 'password',
    ];

    /**
     * The attributes excluded from the model's JSON form.
     *
     * @var array
     */
    protected $hidden = [
        'password', 'remember_token',
    ];
}

5 定義后臺用戶認證路由及控制器

接下來我們來定義后臺用戶認證路由兼砖,修改routes.php代碼如下:

Route::group(['middleware' => ['auth:admin']], function () { //調(diào)用auth中間件時傳遞一個admin參數(shù)

    Route::auth();
    Route::get('home', 'HomeController@index');

    Route::get('admin/login', 'Admin\AuthController@getLogin');
    Route::post('admin/login', 'Admin\AuthController@postLogin');
    Route::get('admin/register', 'Admin\AuthController@getRegister');
    Route::post('admin/register', 'Admin\AuthController@postRegister');
    Route::get('admin', 'AdminController@index');

});

然后使用Artisan命令創(chuàng)建對應控制器:

php artisan make:controller Admin/AuthController

php artisan make:controller AdminController

編輯Admin/AuthController.php代碼如下:

<?php

namespace App\Http\Controllers\Admin;

use App\Admin;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ThrottlesLogins;
use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers;

class AuthController extends Controller
{
    use AuthenticatesAndRegistersUsers, ThrottlesLogins;

    protected $redirectTo = '/admin';
    protected $guard = 'admin';
    protected $loginView = 'admin.login';
    protected $registerView = 'admin.register';

    public function __construct()
    {
        $this->middleware('guest:admin', ['except' => 'logout']);
    }

    protected function validator(array $data)
    {

        return Validator::make($data, [
            'name' => 'required|max:255',
            'email' => 'required|email|max:255|unique:admins',
            'password' => 'required|confirmed|min:6',
        ]);

    }

    protected function create(array $data)
    {
        return Admin::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
        ]);

    }

}

編輯AdminController.php代碼如下:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use App\Http\Requests;
use App\Http\Controllers\Controller;
use Auth;

class AdminController extends Controller
{

    public function __construct()
    {
        $this->middleware('auth:admin');
    }

    public function index()
    {
        $admin = Auth::guard('admin')->user();
        return $admin->name;
    }

}

6 視圖文件創(chuàng)建及修改

最后我們要創(chuàng)建后臺用戶認證對應視圖文件,這里我們簡單拷貝前臺用戶視圖模板并稍作修改即可:

cp -r resources/views/auth resources/views/admin

修改resources/views/admin目錄下登錄及注冊表單提交地址:

/login -> /admin/login
/register -> /admin/register

7 修改 Middleware 文件夾中 Authenticate.php 文件既棺,設(shè)置登錄跳轉(zhuǎn)相應頁面讽挟,代碼如下:

public function handle($request, Closure $next, $guard = null)
    {
        if (Auth::guard($guard)->guest()) {
            if ($request->ajax() || $request->wantsJson()) {
                return response('Unauthorized.', 401);
            } else {
                return redirect()->guest($guard.'/login'); //此行進行修改
            }
        }

        return $next($request);
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市丸冕,隨后出現(xiàn)的幾起案子耽梅,更是在濱河造成了極大的恐慌,老刑警劉巖胖烛,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件眼姐,死亡現(xiàn)場離奇詭異,居然都是意外死亡佩番,警方通過查閱死者的電腦和手機众旗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來趟畏,“玉大人贡歧,你說我怎么就攤上這事「承悖” “怎么了利朵?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長沃琅。 經(jīng)常有香客問我哗咆,道長,這世上最難降的妖魔是什么益眉? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任晌柬,我火速辦了婚禮姥份,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘年碘。我一直安慰自己澈歉,他們只是感情好,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布屿衅。 她就那樣靜靜地躺著埃难,像睡著了一般。 火紅的嫁衣襯著肌膚如雪涤久。 梳的紋絲不亂的頭發(fā)上涡尘,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機與錄音响迂,去河邊找鬼考抄。 笑死,一個胖子當著我的面吹牛蔗彤,可吹牛的內(nèi)容都是我干的川梅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼然遏,長吁一口氣:“原來是場噩夢啊……” “哼贫途!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起待侵,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤丢早,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后诫给,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體香拉,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年中狂,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扑毡。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡胃榕,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出瞄摊,到底是詐尸還是另有隱情勋又,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布换帜,位于F島的核電站楔壤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏惯驼。R本人自食惡果不足惜蹲嚣,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一递瑰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧隙畜,春花似錦抖部、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至言询,卻和暖如春俯萎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背运杭。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工讯屈, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人县习。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓涮母,卻偏偏與公主長得像,于是被迫代替她去往敵國和親躁愿。 傳聞我的和親對象是個殘疾皇子叛本,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內(nèi)容