thinkphp6 session_id 生成规则

/**
     * session_id设置
     * @access public
     * @param string $id session_id
     * @return void
     */
    public function setId($id = null): void
    {
        $this->id = is_string($id) && strlen($id) === 32 && ctype_alnum($id) ? $id : md5(microtime(true) . session_create_id());
    }

自定义setId

Session::setId($session_id);

thinkphp框架会检查 session_id是否字符串,是否长度等于32,是否只包含数字英文.否则随机生成一串md5.

导致自定义的session_id不成功.每次请求都会产生的新的session_id;

解决办法

 public function getSessionId($name)
    {
        $md5Value = md5($name);
        $this->session_id_check($md5Value);
        return $md5Value;
    }

    public function session_id_check($id)
    {
        $res = is_string($id) && strlen($id) === 32 && ctype_alnum($id);
        if (!$res) {
            throw new \Exception("session_id error", 5001);
        }
    }

自定义的session_id先进行检查.

posted @   冯元春  阅读(651)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示