如何使用DbSession在Yii2中创建用户会话管理系统

时间:2017-08-07 00:37:37

标签: php mysql session yii2 user-profile

今天,当我想为我的网站创建用户个人资料页面并希望创建系统用户时,可以在此系统中管理他的活动会话

  • 查看活动会话浏览器和平台
  • 查看当前会话是什么
  • 删除不需要的有效会话

我们如何做到这一点?

1 个答案:

答案 0 :(得分:3)

我找到了将我的用户user_id保存到会话表

的解决方案

Yii2 database session - store additional attributes and user information

Logging out specified user, listing who's online by using DB sessions

但实现此问题还有另一个问题:如何根据浏览器和平台对用户会话进行分类,我找到了这个解决方案。

我在会话数据库中添加了另一列,并在其中使用this class和下面的代码保存了浏览器信息和用户平台信息。

'components' => [
    //...
    'session' => [
                'class' => 'yii\web\DbSession',
                'writeCallback' => function ($session) {
                    $user_browser = null;
                    if (!Yii::$app->user->isGuest) {
                        $browser = new \BrowserDetection();
                        $user_browser = "{$browser->getName()}-{$browser->getPlatform()}" . ($browser->is64bitPlatform() ? "(x64)" : "(x86)") . ($browser->isMobile() ? "-Mobile" : "-Desktop");
                    }
                    return [
                        'user_id' => Yii::$app->user->id,
                        'last_write' => new \yii\db\Expression('NOW()'),
                        'browser_platform' => $user_browser
                    ];
                }
            ],
   // ...
]

注意:您将其他数据添加到会话表

但是为了找到当前会话,我在检查Yii::$app->session->id并返回空字符串值时遇到了问题,我在下面的链接中找到了解决方案。

Blank Session ID in Module's BeforeAction

在Yii2-Advanced中的

我创建frontend\components\baseController并从中扩展所有控制器并创建beforeAction()并在其中打开会话:

namespace frontend\components;
class BaseController extends \yii\web\Controller
{
    public function beforeAction($action)
        {
            if (parent::beforeAction($action)) 
            {
                Yii::$app->session->open();
                return true;
            }
              return false;
    }
}

最后,我为会话数据库创建ActiveRecord模型,并在配置文件页面中使用它来显示或删除用户会话