php session 写入失败怎么办
时间:2021-07-09 15:01
php session写入失败是因为把session误存在memcache里面了,其解决办法就是把session存在redis里面,然后修改php的配置文件即可。 本文操作环境:windows10系统、PHP7.1版,DELL G3电脑 具体问题: php session 写入失败怎么办? php 一直报session写入失败 问题描述 我的代码写入session 的时候一直报这个问题, 环境是windows10 ubuntu 子系统,session 写入的位置是 memcache 6379 端口,扩展都开启了,有大神能解答一下这是什么问题吗? 问题出现的环境背景及自己尝试过哪些方法 相关代码 你期待的结果是什么?实际看到的错误信息又是什么? 解决办法: 已经找到问题所在了,我们现在是把session 存在memcache里面,memcache用的是6379端口, 但是之前我是把session存在redis里面,改了php的配置文件,我忘了这一点,所以一直以为代码有问题。 推荐学习:《PHP视频教程》 以上就是php session 写入失败怎么办的详细内容,更多请关注www.gxlsystem.com其它相关文章!Warning: session_write_close(): Failed to write session data using user defined save handler. (session.save_path: tcp://127.0.0.1:6379) in /var/www/html/php/libs/util/Session.php on line 43
class Session {
// single ton
private static $session_handler_;
public static function Init() {
if (!isset(self::$session_handler_))
self::$session_handler_ = new Session();
}
// 阻止用户复制对象实例
public function __clone() {
trigger_error('Clone Session is not allowed.', E_USER_ERROR);
}
private function __construct() {
session_set_save_handler(array($this, "Open"),
array($this, "Close"),
array($this, "Read"),
array($this, "Write"),
array($this, "Destroy"),
array($this, "Gc"));
// for web user
$session_id = Cookie::Get(SESSIONID);
/* length of session id
128-bit digest (MD5)
4 bits/char: 32 char SID
5 bits/char: 26 char SID
6 bits/char: 22 char SID
160-bit digest (SHA-1)
4 bits/char: 40 char SID
5 bits/char: 32 char SID
6 bits/char: 27 char SID
*/
if (!empty($session_id) && 26 == strlen($session_id))
session_id($session_id);
session_start();
}
public function __destruct() {
session_write_close();
}
public function Open($save_path, $session_name) {
return true;
}
public function Close() {
return true;
}
public function Read($session_id) {
$key = SESSION_PREFIX . $session_id;
$memcached_client_ = SessionMemCachedClient::GetInstance();
return (string)$memcached_client_->get($key);
}
public function Write($session_id, $data) {
$key = SESSION_PREFIX . $session_id;
$memcached_client_ = SessionMemCachedClient::GetInstance();
if ($data)
return $memcached_client_->set($key, $data, SESSION_EXPIRE_TIME);
return true;
}
public function Destroy($session_id) {
$key = SESSION_PREFIX . $session_id;
$memcached_client_ = SessionMemCachedClient::GetInstance();
return $memcached_client_->delete($key);
}
public function Gc($maxlifetime) {
return true;
}
}
Session::Init();