继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

二 laravel blog Auth前后台登录的后台理解

施帅帅
关注TA
已关注
手记 5
粉丝 8
获赞 8
因为时间有限就不展示自己前台代码的书写,就是想巩固一下自己对Auth后台的理解

在RouteServriceProvider区分一下前后台路由代码` public function map()
{
$this->mapApiRoutes();

    $this->homeRoutes();

    $this->adminRoutes();
    //
}

/**
 * Define the "web" routes for the application.
 *
 * These routes all receive session state, CSRF protection, etc.
 *
 * @return void
 *
 * 前台路由
 */
protected function homeRoutes()
{
    Route::middleware('web')
         ->namespace($this->namespace.'\Home')
         ->group(base_path('routes/home.php'));
}
/*
 * 后台路由
 */
protected function adminRoutes()
{
    Route::middleware('web')
        ->namespace($this->namespace.'\Admin')
        ->group(base_path('routes/admin.php'));
}
/**
 * Define the "api" routes for the application.
 *
 * These routes are typically stateless.
 *
 * @return void
 */
protected function mapApiRoutes()
{
    Route::prefix('api')
         ->middleware('api')
         ->namespace($this->namespace)
         ->group(base_path('routes/api.php'));
}`

然后在config auth下注册guard(‘admin’)

  '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,
        ],
        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],

仿User创建Admin model层` use Notifiable;

/**
 * The attributes that are mass assignable.
 *
 * @var array
 */
protected $fillable = [
    'name', 'password',
];

/**
 * The attributes that should be hidden for arrays.
 *
 * @var array
 */
protected $hidden = [
    'password', 'remember_token',
];`

迁移文件填充数据就不展示了


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 = '/admin';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
     //我这里是更改了中间件判断当前用户是否认证通过,如果是admin的话跳转到/admin,就以注释的方式展示
//    public function handle($request, Closure $next, $guard = null)
    //{
    //    if (Auth::guard($guard)->check()) {
      //      return redirect($guard == 'admin' ? '/admin' : '/home');
      //  }
   //     return $next($request);
  //  }
//}

//
//
   public function __construct()
    {
        $this->middleware('guest:admin')->except('logout');
    }
    /*
     * 显示后台登录模板
     *
     */
    public function showLoginForm()
     {
         return view('admin.login');
     }
     /*
      * 验证name字段
      */
    public function username()
    {
        return 'name';
    }

    /*
     * 生成guard(‘admin’)
     */
    protected function guard()
    {
        return auth()->guard('admin');
    }
    /*
     * 验证表单
     */
    protected function validateLogin(Request $request)
    {
        $this->validate($request, [
            $this->username() => 'required|string|max:6',
            'password' => 'required|string|max:6',
        ],[
            $this->username().'required'=>'账号必须填写',
            $this->username().'string'=>'账号必须填写字符串',
            $this->username().'max'=>'账号不大于6位',
            'password.required'=>'密码必须填写',
            'password.string'=>'密码必须填写字符串',
            'password.max'=>'密码不大于6位',
        ]);

    }
    //重写提交登录失败信息
    protected function sendFailedLoginResponse(Request $request)
    {

        $name = $request->name;
        $user=Admin::where('name',$name)->first();
        if(empty($user))
        {
            throw ValidationException::withMessages([
                'name'=>'没有此用户'
            ]);
            return false;
        }
        if (!Hash::check($request->password, $user->password)) {
            throw ValidationException::withMessages([
                'password'=>'密码错误'
            ]);
            return false;
        }

    }
    //用户通过身份认证
    protected function sendLoginResponse(Request $request)
    {

      // 设置记住我的时间为60分钟
        $rememberTokenExpireMinutes = 60;
        // 首先获取 记住我 这个 Cookie 的名字, 这个名字一般是随机生成的,
        // 类似 remember_admin_59ba36addc2b2f9401580f014c7f58ea4e30989d
        $rememberTokenName = Auth::guard('admin')->getRecallerName();
        // 再次设置一次这个 Cookie 的过期时间
        Cookie::queue($rememberTokenName, Cookie::get($rememberTokenName), $rememberTokenExpireMinutes);
        // 下面的代码是从 AuthenticatesUsers 中的 sendLoginResponse() 直接复制而来
        $request->session()->regenerate();

        $this->clearLoginAttempts($request);

        return $this->authenticated($request, $this->guard()->user())
            ?: redirect()->intended($this->redirectPath());

    }

    protected function authenticated(Request $request, $user)
    {

        info('测试日志');
//        return response()->json(['msg'=>200]);
    }

}

我们还要防止用户直接跳过登录访问别的页面
app下的Exceptions/Handler.php//前后端未登录的跳转 protected function unauthenticated($request, AuthenticationException $exception) { if (in_array('admin', $exception->guards())) { return $request->expectsJson() ? response()->json(['msg'=>'用户未登录'], 401) : redirect()->guest(url('admin/login')); } return $request->expectsJson() ? response()->json(['msg'=>'用户未登录'], 401) : redirect()->guest(route('login')); } }
ok然后在路由加个中间件

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP