Laravel5.5+ 区分前后端用户登录

Laravel5.5+ 区分前后端用户登录

Laravel 的用户认证是通过 Auth Facade 门脸实现的,手动认证可是使用  Auth::login() 或 Auth::attempt() 这两个方法实现.

以下内容纯属个人实现,也许有更优的实现方式.

对于识别前后端的用户,可以使用 Auth::guard() 方法实现,前端默认为 web 看守,Auth::guard(‘web’) ,后端用户使用 admin 看守, Auth::guard(‘admin’) .
1.新建 guard 看守

在 config/auth.php 中新建 admin 看守

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

看守的提供者 provider 不变,还是 users .

  'providers' => [
            'users' => [
                'driver' => 'eloquent',
                'model' => App\Models\User::class,
                'table' => 'users',
            ],
     
            // 'users' => [
            //     'driver' => 'database',
            //     'table' => 'users',
            // ],
        ],

这样做的好处是前后端的用户可以放在一张 users 表中,只需要利用状态区分用户就好了,比如 user_status = 1 的是前端用户, user_status = 2 的是后端用户.
2. 新建两个中间件,区分前后端用户登录
Laravel5.5+ 区分前后端用户登录
将新建的中间件添加到 app/Http/Kernel.php 中

 protected $routeMiddleware = [
            ....
     
            'adminVerify' => \App\Http\Middleware\AdminVerify::class,
            'frontVerify' => \App\Http\Middleware\FrontVerify::class,
        ];

在区分前后端用户登录这个功能中,可以废弃默认 Auth 认证中间件 guest.

'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,

这样做的好处是简化了中间件的使用,不用两套系统公用一个 guest 中间件.

我们使用 adminVerify 中间件来做后端认证,所有的后端路由都必须通过这个中间件. adminVerify 中间件如下

   

<?php
     
    namespace App\Http\Middleware;
     
    use Closure;
    use Illuminate\Support\Facades\Auth;
     
    class AdminVerify
    {
        /**
         * Handle an incoming request.
         *
         * @param  \Illuminate\Http\Request $request
         * @param  \Closure $next
         * @return mixed
         */
        public function handle($request, Closure $next)
        {
            $current_uri = $request->getRequestUri();
            $ignore_uri = [
                '/admin/login',
                '/admin/logout'
            ];
            if (in_array($current_uri, $ignore_uri)) {
                return $next($request);
            } else {
                if (Auth::guard('admin')->check()) {
                    return $next($request);
                } else {
                    return redirect('/admin/login');
                }
            }
     
        }
    }

使用 frontVerify 中间件来做前端认证,所有的前端路由都必须通过这个中间件. frontVerify 中间件如下

 <?php
     
    namespace App\Http\Middleware;
     
    use Closure;
    use Illuminate\Support\Facades\Auth;
     
    class FrontVerify
    {
        /**
         * Handle an incoming request.
         *
         * @param  \Illuminate\Http\Request $request
         * @param  \Closure $next
         * @return mixed
         */
        public function handle($request, Closure $next)
        {
            $current_uri = $request->getRequestUri();
            $ignore_uri = [
                '/login',
                '/logout'
            ];
            if (in_array($current_uri, $ignore_uri)) {
                return $next($request);
            } else {
                if (Auth::guard('web')->check()) {
                    return $next($request);
                } else {
                    return redirect('/login');
                }
            }
        }
    }

3. 路由设置

默认所有的前端路由都没有前缀,所有的后端路由都带有 admin 前缀. 路由设置如下.

 // ==== 前后端登录
    // 前端
    Route::group(['middleware' => ['frontVerify']], function () {
        Route::get('/', 'Front\LoginController@index')->name('front_index');
        Route::get('login', 'Front\LoginController@login');
        Route::post('login', 'Front\LoginController@store')->name('front_login');
        Route::get('logout', 'Front\LoginController@logout')->name('front_logout');
        Route::get('login-success', 'Front\LoginController@success')->name('front_success');
    });
     
     
    // 后端
    Route::group(['prefix' => 'admin', 'middleware' => ['adminVerify']], function () {
        Route::get('/', 'Admin\LoginController@index')->name('admin_index');
        Route::get('login', 'Admin\LoginController@login');
        Route::post('login', 'Admin\LoginController@store')->name('admin_login');
        Route::get('logout', 'Admin\LoginController@logout')->name('admin_logout');
        Route::get('login-success', 'Admin\LoginController@success')->name('admin_success');
    });
     
    // ==== 前后端登录 END

前后端都有一个 login-success 页面,这两个页面的内容是一模一样的,除了文字不一样.

以下是后端页面的 login-success 页面

<h1>后端登录成功</h1>
    我是 admin guard -- {
    { \Illuminate\Support\Facades\Auth::guard('admin')->check() }}
    =====
    我是 web guard -- {
    { \Illuminate\Support\Facades\Auth::guard('web')->check() }}

前端的 login-success 页面

    <h1>前端登录成功</h1>
    我是 admin guard -- {
    { \Illuminate\Support\Facades\Auth::guard('admin')->check() }}
    =====
    我是 web guard -- {
    { \Illuminate\Support\Facades\Auth::guard('web')->check() }}

路由列表中前端有一个首页 / ,后端也有一个默认的首页 /admin/,这两个首页的作用是验证未登录的用户是不能访问前后端的任何一个页面的,如果通过路由访问,并且是在没有登录的情况下,那么在中间件中就让其自动跳到对应的登录页面,具体可以看中间件的代码.
4 . 具体登录代码实现
4.1.1 前端登录

   

<?php
     
    namespace App\Http\Controllers\Front;
     
    use App\Http\Controllers\Controller;
    use Illuminate\Foundation\Auth\AuthenticatesUsers;
    use Illuminate\Http\Request;
    use Illuminate\Support\Facades\Auth;
     
    class LoginController extends Controller
    {
        //
        use AuthenticatesUsers;
     
        /**
         * LoginController constructor.
         */
        public function __construct()
        {
        }
     
     
        public function index()
        {
            return view('front.index');
        }
     
        public function login(Request $request)
        {
            return view('front.login');
        }
     
        public function store(Request $request)
        {
            $credentials = $this->validate($request, [
                'phone' => 'required|max:255',
                'password' => 'required'
            ]);
     
            $rs = $this->guard()->attempt($credentials);
            if ($rs) {
                return redirect()->route('front_success');
            } else {
                return back();
            }
        }
     
        public function logout(Request $request)
        {
            $this->guard()->logout();
            $request->session()->flush();
            return redirect()->route('front_login');
        }
     
     
        public function success(Request $request)
        {
            return view('front.success');
        }
     
        protected function guard()
        {
            return Auth::guard('web');
        }
     
    }

4.1.2 后端登录

  

 <?php
    /**
     * Created by PhpStorm.
     * User: nwei
     * Date: 2018/12/21
     * Time: 16:19
     */
     
    namespace App\Http\Controllers\Admin;
     
     
    use App\Http\Controllers\Controller;
    use Illuminate\Http\Request;
    use Illuminate\Support\Facades\Auth;
     
    class LoginController extends Controller
    {
        /**
         * LoginController constructor.
         * @param string $redirectTo
         */
        public function __construct()
        {
        }
     
        public function index()
        {
            return view('admin.index');
        }
     
     
        public function login()
        {
            return view('admin.login');
        }
     
        public function store(Request $request)
        {
            $credentials = $this->validate($request, [
                'phone' => 'required|max:255',
                'password' => 'required'
            ]);
     
            $rs = $this->guard()->attempt($credentials);
            if ($rs) {
                return redirect()->route('admin_success');
            } else {
                return back();
            }
        }
     
     
        public function success()
        {
            return view('admin.success');
        }
     
     
        public function logout(Request $request)
        {
            $this->guard()->logout();
            $request->session()->flush();
            return redirect('admin/login');
        }
     
     
        protected function guard()
        {
            return Auth::guard('admin');
        }
     
     
    }

4.2 登录结果
4.2.1 前端登录结果
Laravel5.5+ 区分前后端用户登录
4.2.2 开一个隐身模式,测试后端登录结果
Laravel5.5+ 区分前后端用户登录
测试成功!

 
    类似博文:

    https://segmentfault.com/a/1190000007716366

原文:https://blog.csdn.net/xiaobinqt/article/details/85230617

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112404.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jar包打入maven仓库中_maven打包引入外部jar包

    jar包打入maven仓库中_maven打包引入外部jar包一、申请GroupId我们知道,一个maven坐标由groupId,artifactId和version组成,后两者可以在pom中调整,而可以用在中央仓库的groupId需要申请。由于Maven

    2022年8月16日
    3
  • 什么叫侧面指纹识别_又见侧面指纹,四大指纹识别技术,你会如何选择?「建议收藏」

    什么叫侧面指纹识别_又见侧面指纹,四大指纹识别技术,你会如何选择?「建议收藏」原标题:又见侧面指纹,四大指纹识别技术,你会如何选择?1.正面实体指纹系统关于最早搭载正面指纹识别技术的手机,估计大家都会说是苹果公司在2013年9月发布的iPhone5s。其实最早的应该是摩托罗拉公司。只是苹果公司的影响比较大,在iPhone5s之后,将这项技术推向了颠峰,引领了潮流。之后各大手机厂商也纷纷加入了这个行列,越来越多的指纹识别手机面世。得益于苹果手机传统的HOME键,刚好可…

    2022年6月29日
    30
  • 什么是Lambda架构?

    什么是Lambda架构?写在前面本文隶属于专栏《100个问题搞定大数据理论体系》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢!本专栏目录结构和文献引用请见100个问题搞定大数据理论体系解答1.Lambda架构定义了一套面向大数据应用的模式和准则。更重要的是,它允许同时查询历史数据和实时新增的数据,并且获得期望的分析视图。2.处理历史数据(批处理)和实时数据。3.技术无关和通用性。Lambda架构是一种通用的模式,完全不依赖于任何技术,而且任何技术只要能满足需求,都可以在Lamb

    2022年6月25日
    25
  • Ubuntu 系统 dpkg 命令使用详解

    Ubuntu 系统 dpkg 命令使用详解dpkg即packagemanagerforDebian,是Debian和基于Debian的系统中一个主要的包管理工具,可以用来安装、构建、卸载、管理deb格式的软件包。安装软件使用dpkg命令安装软件时,可以使用-i选项并指定deb安装包的路径。和Ubuntu下的另一个包管理工具apt-get(AdvancedPackageTool)有所不同。apt-get命令并不直接操作deb安装包文件,而是从/etc/apt/s…

    2022年5月11日
    54
  • 柚子快报 app 拼多多助力是真的吗_柚子说APP

    柚子快报 app 拼多多助力是真的吗_柚子说APP今天在这个平台发布了拼多多助力任务开始五个任务,还都是助力成功的,背后发的17任务,只有一个助力成功这是正常的嘛存不存在平台自己P图骗赏金

    2022年10月26日
    0
  • flashfxp 5.4.0.3970 绿色汉化版注册码[通俗易懂]

    flashfxp 5.4.0.3970 绿色汉化版注册码[通俗易懂]FlashFXPRegistrationDataSTARTFLASHFXP0wC2kbML0wAAAADEW5MNJwTnsl790jgG5F4CTA4jUAdMi66HHqFbShaEpE

    2022年7月1日
    138

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号