发布于 1970-01-01 08:00
  • 1 个回答
    • 提问应该尽可能多的提供线索,比如你的 SQL 语句是什么样的,这样别人在测试的时候方便多了,我现在还需要自己来创建:

      sqlCREATE TABLE `session` (
        `session_id` char(128) DEFAULT NULL,
        `expire` int(11) DEFAULT NULL,
        `session_value` text
      ) ENGINE=MyISAM DEFAULT CHARSET=utf8
      

      环境信息也尽可能的提供,比如我的代码可以运行在 php 5.5.16-pl0-gentoo

      问题1、你的表名有问题,读的时候用了,sessions ; 写的时候是用的 session

      问题2、貌似通过 open 方法时打开的数据库链接在其它地方用不了,(这个原因我也不清楚,后面可以了解下为什么),去官方看了下,都是使用的 class 来完成的。所以把你的改成了 OOP 的形式测试可用。

      <?php
      ob_end_clean();
      if((int)ini_get('session.auto_start') > 0)
      {
          ini_set('session.auto_start',0);
      }
      
      class MySqlSessionHandler implements SessionHandlerInterface
      {
      private $_db;
      
      public function close()
      {
          return $this->_db->close();
      }
      
      public function destroy($sessionn_id)
      {
          $sql = 'delete from sessions where session_id="'.$session_id.'"';
          $this->_db->query($sql);
          $_SESSION = array();
          return TRUE;
      }
      
      public function gc($maxlifetime)
      {
          $sql = 'delete from sessions where expire < '.time();
          $zen_session_db->query($sql);
          return TRUE;
      }
      
      public function open($save_path, $name)
      {
          $this->_db = new mysqli('localhost','root','password','test');
          return (boolean)$this->_db;
      }
      
      public function read($session_id)
      {
          $sql = 'select session_value from sessions where session_id="'.$session_id.'"';
          $query = $this->_db->query($sql);
          if($this->_db->errno) {
              die($this->_db->error);
          }
          if($query -> num_rows == 1) {
              $session_data = $query->fetch_assoc();
              return $session_data['session_value'];
          } else {
              return "";
          }
      }
      
      public function write($session_id, $session_data)
      {
          $sql = 'select count(*) as count from sessions where session_id="'.$session_id.'"';
          $query = $this->_db->query($sql);
          $result = $query->fetch_assoc();
          if($this->_db->errno) {
              die($this->_db->error);
          }
          if($result['count'] > 0)
          {
              $sql = 'update sessions set session_value=\''.$session_data.'\',expire='.(time()+60*60).' where session_id="'.
                  $session_id.'"';
              $this->_db->query($sql);
          } else {
              $sql = 'insert into sessions values("'.$session_id.'","'.(time()+60*60).'",\''.$session_data.'\')';
              $this->_db->query($sql);
          }
          if($this->_db->affected_rows > 0) {
              return TRUE;
          } else {
              return FALSE;
          }
          }
      }
      
      $handler = new MySqlSessionHandler;
      session_set_save_handler($handler, true);
      
      session_name('zenID');
      session_start();
      $_SESSION['age'] = 17;
      $_SESSION['color'] = 'green';
      $_SESSION['color2'] = 'red';
      
      2022-12-01 18:51 回答
    撰写答案
    今天,你开发时遇到什么问题呢?
    立即提问
    PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有