Laravel 用户认证的疑问

Sessionguard类中的getName()方法:

 /**
     * Get a unique identifier for the auth session value.
     *
     * @return string
     */
    public function getName()
    {
        return 'login_'.$this->name.'_'.sha1(static::class);
    }

是如何确定唯一的session id,并从中拿到当前登录用户的?

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 3

SessionGuard里面的name只是你应用使用的guard名,在配置文件auth.php的defaults选项里,比如你使用的是web,那么这个name就是web,SessionGuard::getName()返回的字符串只是session数组里的一个key而已,而这个key对应的value就是当前登录用的ID。

你想了解Session的具体流程应该看illuminate/session

7年前 评论

试了一下, sessionguard会为每一个客户端保存一个session文件,这个session文件里面存储有当前用户的id。 session文件里面还有一些奇怪的东西。具体是怎样用cookie找到对应的session还要看session的代码。

7年前 评论

@coodeer 恩恩 现在已经明白着整个流程了 是在sessionstart中间件中处理cookie和session的

7年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!