繁体   English   中英

如何获取存储在数据库中的会话ID?

[英]How to get the session ID stored in database?

我试图通过制作另一个模型Sessions在会话表中添加额外的信息。 我正在使用以下问题答案中详述的方法;

Laravel会话表添加了其他列

领域:

  • id - varchar(50) - laravel在这里存储一个40个字符的字符串
  • payload - mediumtext - 通常为265个字符的字符串
  • last_activity - int(11)
  • user_id - bigint(20)
  • type - varchar(15) - 默认('biz')
  • created_at - timestamp - 默认值(CURRENT_TIMESTAMP)

模型

class Sessions extends BaseModel
{
    protected $table = 'sessions';
    protected $fillable = array(
        'id', 
        'payload', 
        'last_activity', 
        'user_id', 
        'type', 
        'created_at');

    public static function getCurrent()
    {
        return Sessions::find(Session::getId());
    }
} 

调节器

public function postLogin()
{
    if (\Auth::biz()->attempt(\Input::only(array('email', 'password')), 
        \Input::get('persist', 'no') == 'yes')) {
        $session = Sessions::getCurrent(); // returns NULL
        // fields getting values
        $session->save();
        return \Redirect::route('marketer.home');
    } else {
        return \Redirect::back()->withInput()->with('loginFail', true);
    }
}

我正在使用laravel v4.2.16与基于数据库的会话管理。 函数Session::getId()不返回存储在数据库中的id,因此我无法通过我的Sessions::getCurrent()方法获取当前会话的模态。

该方法之前有效,因此我们在其上构建了许多优化查询。

尝试这个:

$user = \Auth::user(); in the view file

然后将$ user变量打印为:

echo "<pre>";
print_r($user);
echo "</pre>";
exit;

看,如果这有帮助。

你需要调用静态Session::unguard(); 获取id然后Session::reguard();

暂无
暂无

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

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