繁体   English   中英

Laravel中的多会话表

[英]Multi session tables in Laravel

我已经建立了一个带有两个Higuard自己的用户表的警卫队的Laravel项目。 现在我想将会话保存到数据库中而不是文件中。 问题是我无法将会话保存在单个表中,因为用户ID不是唯一的。 我怎么解决这个问题? 谢谢。

我试过了 此方法有效,但是它存在默认的会话驱动程序,因此用户在默认表和admin_sessions表中都有一个会话。

class AuthServiceProvider extends ServiceProvider
{
    protected $policies = [
        Administrator::class => UserPolicy::class,
    ];

    public function boot()
    {
        $this->registerPolicies();

        Auth::extend('admin_session', function ($app, $name, array $config) {

            $provider = Auth::createUserProvider($config['provider']);
            $guard = new SessionGuard($name, $provider, $app->session->driver('admin_database'));

            if (method_exists($guard, 'setCookieJar')) {
                $guard->setCookieJar($this->app['cookie']);
            }

            if (method_exists($guard, 'setDispatcher')) {
                $guard->setDispatcher($this->app['events']);
            }

            if (method_exists($guard, 'setRequest')) {
                $guard->setRequest($this->app->refresh('request', $guard, 'setRequest'));
            }

            return $guard;
    }
}


class SessionServiceProvider extends ServiceProvider
{

    /**
     * Register the service provider.
     *
     * @return void
     */
    public function register()
    {
    }


    /**
     * Perform post-registration booting of services.
     *
     * @return void
     */
    public function boot()
    {
        $this->app->session->extend('admin_database', function ($app) {

            $table = 'administrator_sessions';

            // This is not workin, because I don't have the user her.
            /*if (auth()->user() instanceof Customer) {
                $table = 'customer_sessions';
            }
            else if (auth()->user() instanceof Administrator){
                $table = 'administrator_sessions';
            }*/

            $lifetime = $app['config']['session.lifetime'];
            $connection = $app['db']->connection($app['config']['session.connection']);

            return new DatabaseSessionHandler($connection, $table, $lifetime, $app);
        });
    }

}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM