打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Session类简单实现
/** * Session类简单实现 * @author zhjx922 */class Session{    //当前sessionId    private $_sessionId;    //session的储存路径    private $_sessionPath = '/tmp/session';    /**     * 初始化sessionId     */    public function __construct()    {        if(isset($_COOKIE['PHPSESSID']) && $this->checkSession($_COOKIE['PHPSESSID'])) {            $this->_sessionId = $_COOKIE['PHPSESSID'];        } else {            $this->_sessionId = uniqid();            setcookie("PHPSESSID", $this->_sessionId);        }    }    /**     * 设置session     * @param string $key     * @param mixed $value     */    public function setSession($key, $value)    {        $sessionInfo = $this->getSessionInfo();        $sessionInfo[$key] = $value;        $sessionFile =  "{$this->_sessionPath}/{$this->_sessionId}";        file_put_contents($sessionFile, serialize($sessionInfo));    }    /**     * 获取session     * @param string $key     * @return mixed     */    public function getSession($key)    {        return $this->getSessionInfo()[$key];    }    /**     * 获取当前sessionId下的内容     * @return array     */    private function getSessionInfo()    {        if(!is_dir($this->_sessionPath))        {            mkdir($this->_sessionPath);        }        $sessionFile =  "{$this->_sessionPath}/{$this->_sessionId}";        if(is_file($sessionFile)) {            $contents = file_get_contents($sessionFile);            return unserialize($contents);        }        return [];    }    /**     * 检查session是否有效     * @param string $sessionId     * @return bool     */    private function checkSession($sessionId)    {        $sessionFile =  "{$this->_sessionPath}/{$sessionId}";        if(is_file($sessionFile)) {            return true;        }        return false;    }}

使用方法如下

$session = new Session();$session->setSession('a', 'b'); //第二次访问时注释掉这行,验证下一行$session->getSession('a')输出的内容是否正确var_dump($session->getSession('a'));
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
jetty对sessionId的处理分析
构建不依赖于cookie的手机端用户登录机制
会话固定漏洞的一点学习、分析与思考
PHP中的session安全吗
apache shiro集群实现(一) session共享
深入理解Servlet/JSP之“Cookie和Session原理”
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服