php session写入失败是因为把session误存在memcache里面了,其解决办法就是把session存在redis里面,然后修改php的配置文件即可。
![](https://img1.php1.cn/3cd4a/24c6f/3b4/7e63688ee7181f5b.jpeg)
本文操作环境:windows10系统、PHP7.1版,DELL G3电脑
具体问题:
php session 写入失败怎么办?
php 一直报session写入失败
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
![1625796748305452.png 114e523bdc0943b24cd9daf932d215b.png](https://img1.php1.cn/3cd4a/24c6f/3b4/e4a3c3ef5e5c9f01.png)
问题描述
我的代码写入session 的时候一直报这个问题, 环境是windows10 ubuntu 子系统,session 写入的位置是 memcache 6379 端口,扩展都开启了,有大神能解答一下这是什么问题吗?
问题出现的环境背景及自己尝试过哪些方法
相关代码
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();
你期待的结果是什么?实际看到的错误信息又是什么?
解决办法:
已经找到问题所在了,我们现在是把session 存在memcache里面,memcache用的是6379端口, 但是之前我是把session存在redis里面,改了php的配置文件,我忘了这一点,所以一直以为代码有问题。
推荐学习:《PHP视频教程》