laravel auth.php,laravel Auth类使用指定的guard

本文详细介绍了在Laravel框架中如何创建独立的后台管理模块,并配置Admin Guard进行用户验证。通过生成Admin模型、数据迁移、填充数据、定义路由、编写控制器以及中间件,确保后台登录验证的安全性和独立性。同时,强调了在使用Auth助手函数时指定guard的重要性。
摘要由CSDN通过智能技术生成

在网站的登录验证逻辑中,为了好维护,一般后台会独立出来一个模块, 此时就不能和前台的模块混到一起去验证, 需要单独为后台指定一个guard(提供数据的)

20d4bcde77cc

auth

laravel 的Auth是由两个部分组成的

后台登录 指定guard 不用默认的 users 表

准备

生成admin模型 同时 迁移 admin 表

php artisan make:model Admin -m

填充数据

修改 database/factories/ModelFactory.php

$factory->define(App\Admin::class, function (Faker\Generator $faker) {

static $password;

return [

'account' => $faker->unique()->safeEmail,

'nickname' => $faker->name,

'password' => $password ?: $password = bcrypt('123456')

];

});

生成填充数据文件

php make:seed AdminTableSeeder

修改填充数据文件

use Illuminate\Database\Seeder;

class AdminTableSeeder extends Seeder

{

/**

* Run the database seeds.

*

* @return void

*/

public function run()

{

factory(\App\Admin::class)->times(10)->create();

}

}

执行填充

php artisan db:seed --class=AdminTableSeeder

一切准备好之后, 就开始写代码..

1. 添加路由

Route::group(['prefix' => '/admin', 'namespace' => 'Admin'], function () {

Route::get('/login', 'AuthController@index');

Route::post('/login', 'AuthController@login');

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

// 需要通过 admin 中间件才能访问的路由

Route::get('/', 'IndexController@index');

Route::get('/user', 'AuthController@user');

});

});

2. 修改 /App/Admin 模型

namespace App;

use Illuminate\Database\Eloquent\Model;

use Illuminate\Foundation\Auth\User as AdminAuth;

class Admin extends AdminAuth

{

protected $fillable = [

'name', 'password', 'avatar', 'nickname'

];

protected $hidden = [

'password'

];

}

3. AuthController

namespace App\Http\Controllers\Admin;

use Illuminate\Http\Request;

use App\Http\Controllers\Controller;

/**

* Class AuthController

* @package App\Http\Controllers\Admin

*/

class AuthController extends Controller

{

public function index()

{

return view('admin.login'); // 登录视图

}

/**

* @param Request $request

* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector

*/

public function login(Request $request)

{

$account = $request->input('account');

$password = $request->input('password');

if (\auth('admin')->attempt(['account' => $account, 'password' => $password])) {

return redirect('/admin');

}

return back();

}

/**

* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector

*/

public function logout()

{

\auth('admin')->logout();

return redirect('/admin/login');

}

/**

* get current usre info

* @return \Illuminate\Contracts\Auth\Authenticatable|null

*/

public function user()

{

return \auth('admin')->user();

}

}

4. 修改 /config/auth.php

添加一个 admin guard

为 admin 这个 guard 指定 provider

'guards' => [

'web' => [

'driver' => 'session',

'provider' => 'users',

],

// 添加 admin guard

'admin' => [

'driver' => 'session',

'provider' => 'admin'

],

'api' => [

'driver' => 'token',

'provider' => 'users',

],

],

'providers' => [

'users' => [

'driver' => 'eloquent',

'model' => App\User::class,

],

// 添加admin provider, 简单理解,就是指定提供数据的模型

'admin' => [

'driver' => 'eloquent',

'model' => App\Admin::class,

],

],

5. 注册中间件

生成中间件

php artisan make:middleware AdminAuth

在中间件中验证

namespace App\Http\Middleware;

use Closure;

class AdminAuth

{

/**

* Handle an incoming request.

*

* @param \Illuminate\Http\Request $request

* @param \Closure $next

* @return mixed

*/

public function handle($request, Closure $next)

{

if (!\auth('admin')->check()) {

return redirect('/admin/login');

}

return $next($request);

}

}

测试

....这个就自己测试

注意事项

建议使用 \auth('admin') 这种助手函数的形式 Auth::guard('admin') 这个Auth是需要use的, 用助手函数就不用 use 了

在使用 auth 的时候一定注意要指定 guard, 如果不指定laravel 默认使用的是的是 web 这个guard

20d4bcde77cc

一图胜千言

最后

自己动手敲 1次比看别人文章100次理解更深刻

纸上得来终觉浅,绝知此事要躬行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值