PHP7 使用session_set_save_handler
项目原本是在php5.4.45-nts运行的,后面升级到PHP7,发现session总是存储不了
我的session是通过session_set_save_handler自定义存储到数据库中
正常的seesion过程应该是open->read->write->close
升级PHP后变成了open->read->close
所以就去检查了read函数
public function read($sessID) { $sql = "SELECT session_data AS d FROM " . $this->prefix . "sessions WHERE session_id = "" . $sessID . "" AND session_expires >" . TIMES; $row = $this->db->get_one($sql); if ($row) { $data = $row["d"]; return $data; } return false; }
在没有数据的时候 retrun false;
最终确定问题也是这个return false;修改为return "";即可
具体原因我也不是很清楚,应该是return false导致session自己直接跳过write了
附上完整的重写函数:
<?php class db_sessions extends app_models { public $lifeTime = ""; public function db_sessions() { parent::__construct(); session_set_save_handler(array(&$this, "open"), array(&$this, "close"), array(&$this, "read"), array(&$this, "write"), array(&$this, "destroy"), array(&$this, "gc")); } public function open($savePath, $sessName) { $this->lifeTime = 3600; return true; } public function close() { $this->gc(ini_get("session.gc_maxlifetime")); return true; } public function read($sessID) { $sql = "SELECT session_data AS d FROM " . $this->prefix . "sessions WHERE session_id = "" . $sessID . "" AND session_expires >" . TIMES; $row = $this->db->get_one($sql); if ($row) { $data = $row["d"]; return $data; } return ""; } public function write($sessID, $sessData) { if (!($sessData)) { return false; } $newExp = TIMES + $this->lifeTime; $sql = "SELECT * FROM " . $this->prefix . "sessions WHERE session_id = "" . $sessID . """; $num = $this->db->get_num($sql); if ($num) { $this->db->query("UPDATE " . $this->prefix . "sessions SET session_expires = "" . $newExp . "", session_data = "" . $sessData . "" WHERE session_id = "" . $sessID . """); if ($this->db->affected_rows()) { return true; } } else { $this->db->query("INSERT INTO " . $this->prefix . "sessions ( session_id, session_expires, session_data) VALUES( "" . $sessID . "", "" . $newExp . "", "" . $sessData . "")"); if ($this->db->affected_rows()) { return true; } } return false; } public function destroy($sessID) { $this->db->query("DELETE FROM " . $this->prefix . "sessions WHERE session_id = "" . $sessID . """); if ($this->db->affected_rows()) { return true; } return false; } public function gc($sessMaxLifeTime) { $this->db->query("DELETE FROM " . $this->prefix . "sessions WHERE session_expires < " . TIMES); return true; } public function __destruct() { session_write_close(); } } ?>
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。