【问题标题】:Laravel- Multiauth is not working in Laravel 5.2Laravel-Multiauth 在 Laravel 5.2 中不起作用
【发布时间】:2016-06-01 04:28:14
【问题描述】:

我正在尝试在laravel 5.2 中实现多重身份验证。我关注this article

我的Auth.php

<?php

return [
 'multi' => array(
   'user' => array(
     'driver' => 'eloquent',
     'model' => 'App\User',
     'table' => 'users',
   ),
   'admin' => array(
     'driver' => 'database',
     'model' => 'App\Admin',
     'table' => 'tbl_admin_user',
   )
 ),
 'password' => [
 'email' => 'emails.password',
 'table' => 'password_resets',
 'expire' => 60,
 ],
];

我的App.php

'providers' => [

        /*
         * Laravel Framework Service Providers...
         */
        //Illuminate\Auth\AuthServiceProvider::class,
        Ollieread\Multiauth\MultiauthServiceProvider::class,
        Illuminate\Broadcasting\BroadcastServiceProvider::class,
        Illuminate\Bus\BusServiceProvider::class,
        Illuminate\Cache\CacheServiceProvider::class,
        Illuminate\Foundation\Providers\ConsoleSupportServiceProvider::class,
        Illuminate\Cookie\CookieServiceProvider::class,
        Illuminate\Database\DatabaseServiceProvider::class,
        Illuminate\Encryption\EncryptionServiceProvider::class,
        Illuminate\Filesystem\FilesystemServiceProvider::class,
        Illuminate\Foundation\Providers\FoundationServiceProvider::class,
        Illuminate\Hashing\HashServiceProvider::class,
        Illuminate\Mail\MailServiceProvider::class,
        Illuminate\Pagination\PaginationServiceProvider::class,
        Illuminate\Pipeline\PipelineServiceProvider::class,
        Illuminate\Queue\QueueServiceProvider::class,
        Illuminate\Redis\RedisServiceProvider::class,
        Illuminate\Auth\Passwords\PasswordResetServiceProvider::class,
        Illuminate\Session\SessionServiceProvider::class,
        Illuminate\Translation\TranslationServiceProvider::class,
        Illuminate\Validation\ValidationServiceProvider::class,
        Illuminate\View\ViewServiceProvider::class,

        /*
         * Application Service Providers...
         */
        App\Providers\AppServiceProvider::class,
        App\Providers\AuthServiceProvider::class,
        App\Providers\EventServiceProvider::class,
        App\Providers\RouteServiceProvider::class,

    ],

    /*
    |--------------------------------------------------------------------------
    | Class Aliases
    |--------------------------------------------------------------------------
    |
    | This array of class aliases will be registered when this application
    | is started. However, feel free to register as many as you wish as
    | the aliases are "lazy" loaded so they don't hinder performance.
    |
    */

    'aliases' => [

        'App' => Illuminate\Support\Facades\App::class,
        'Artisan' => Illuminate\Support\Facades\Artisan::class,
        'Auth' => Illuminate\Support\Facades\Auth::class,
        'Blade' => Illuminate\Support\Facades\Blade::class,
        'Cache' => Illuminate\Support\Facades\Cache::class,
        'Config' => Illuminate\Support\Facades\Config::class,
        'Cookie' => Illuminate\Support\Facades\Cookie::class,
        'Crypt' => Illuminate\Support\Facades\Crypt::class,
        'DB' => Illuminate\Support\Facades\DB::class,
        'Eloquent' => Illuminate\Database\Eloquent\Model::class,
        'Event' => Illuminate\Support\Facades\Event::class,
        'File' => Illuminate\Support\Facades\File::class,
        'Gate' => Illuminate\Support\Facades\Gate::class,
        'Hash' => Illuminate\Support\Facades\Hash::class,
        'Lang' => Illuminate\Support\Facades\Lang::class,
        'Log' => Illuminate\Support\Facades\Log::class,
        'Mail' => Illuminate\Support\Facades\Mail::class,
        'Password' => Illuminate\Support\Facades\Password::class,
        'Queue' => Illuminate\Support\Facades\Queue::class,
        'Redirect' => Illuminate\Support\Facades\Redirect::class,
        'Redis' => Illuminate\Support\Facades\Redis::class,
        'Request' => Illuminate\Support\Facades\Request::class,
        'Response' => Illuminate\Support\Facades\Response::class,
        'Route' => Illuminate\Support\Facades\Route::class,
        'Schema' => Illuminate\Support\Facades\Schema::class,
        'Session' => Illuminate\Support\Facades\Session::class,
        'Storage' => Illuminate\Support\Facades\Storage::class,
        'URL' => Illuminate\Support\Facades\URL::class,
        'Validator' => Illuminate\Support\Facades\Validator::class,
        'View' => Illuminate\Support\Facades\View::class,

    ],

];

当我运行项目时,我看到了错误

调用未定义的方法 Illuminate\Foundation\Application::bindShared() 在 MultiauthServiceProvider.php 第 13 行

我把MultiAuthServiceProvider.php改成了

$this->app->singleton('auth', function ($app) {
        $app['auth.loaded'] = true;

        return new \Ollieread\Multiauth\MultiManager($app);
    });

现在我在屏幕截图中看到了这个错误 我不确定是什么试图实例化Gate Facade

【问题讨论】:

    标签: php authentication laravel-5.2


    【解决方案1】:

    我建议您使用 Laravel 自定义身份验证guard 和身份验证provider,而不是创建这样的自定义多重身份验证。老实说,第二种方法还没有经过测试,但我认为它应该可以工作。

    1.一个模型多个后卫

    在你的config/auth.php 上添加一个新的守卫:

    'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
    
        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    
        // new guard for admin using the same model and table.
        'admin' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
    ],
    

    然后使用auth:admin对你的路由进行分组,当然你还必须创建另一个可以检查当前用户是否为管理员用户的中间件。要获取经过身份验证的用户实例,您需要指定自定义保护:Auth::guard('admin')-&gt;user()

    为了确保它正常工作,创建两个路由组,一个使用auth 中间件,一个使用auth:admin 中间件,当您在使用auth:admin 的路由上登录用户时,尝试访问您应该访问的其他路由组要求重新登录。

    Route::group(['middleware' => 'auth'], function () {
        Route::get('/', function () {
            return 'You are logged in using guard: web';
        });
    });
    
    Route::group(['middleware' => 'auth:admin'], function () {
        Route::get('/admin', function () {
            return 'You are logged in using guard: admin';
        });
    });
    

    2。多种型号

    再次在您的 config/auth.php 上,创建新的自定义提供程序:

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

    然后使用admins 作为提供者创建一个自定义守卫:

    'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
    
        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    
        // new guard for admin using custom provider.
        'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],
    ],
    

    使用这种方法不需要创建自定义中间件,使用auth:admin就可以了。

    【讨论】:

    • 我尝试了Laravel 这个答案stackoverflow.com/questions/34614753/… 中解释的方式,但它只在用户表中注册了我
    • 您的意思是当您注册Admin 用户时,它会转到users 表?如果是这样,那么您必须仍然在create()AuthController 方法上使用User 模型。
    • 在您的AuthController 上进行管理员身份验证,您必须通过添加此属性protected $guard = 'admin'; 来指定自定义防护
    猜你喜欢
    • 2017-05-22
    • 2017-08-08
    • 2017-01-06
    • 2017-01-06
    • 2023-03-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-04-01
    相关资源
    最近更新 更多