feat: 同步下新环境

This commit is contained in:
笔记本里的永平
2025-07-07 11:31:25 +08:00
parent 3d1050db3d
commit 86c261ba70
196 changed files with 13146 additions and 29319 deletions

View File

@@ -11,10 +11,10 @@
namespace think\session\driver;
use SessionHandlerInterface;
use SessionHandler;
use think\Exception;
class Memcache implements SessionHandlerInterface
class Memcache extends SessionHandler
{
protected $handler = null;
protected $config = [
@@ -34,8 +34,8 @@ class Memcache implements SessionHandlerInterface
/**
* 打开Session
* @access public
* @param string $savePath
* @param mixed $sessName
* @param string $savePath
* @param mixed $sessName
*/
public function open($savePath, $sessName)
{
@@ -43,17 +43,13 @@ class Memcache implements SessionHandlerInterface
if (!extension_loaded('memcache')) {
throw new Exception('not support:memcache');
}
$this->handler = new \Memcache;
// 支持集群
$hosts = explode(',', $this->config['host']);
$ports = explode(',', $this->config['port']);
if (empty($ports[0])) {
$ports[0] = 11211;
}
// 建立连接
foreach ((array) $hosts as $i => $host) {
$port = isset($ports[$i]) ? $ports[$i] : $ports[0];
@@ -61,7 +57,6 @@ class Memcache implements SessionHandlerInterface
$this->handler->addServer($host, $port, $this->config['persistent'], 1, $this->config['timeout']) :
$this->handler->addServer($host, $port, $this->config['persistent'], 1);
}
return true;
}
@@ -74,14 +69,13 @@ class Memcache implements SessionHandlerInterface
$this->gc(ini_get('session.gc_maxlifetime'));
$this->handler->close();
$this->handler = null;
return true;
}
/**
* 读取Session
* @access public
* @param string $sessID
* @param string $sessID
*/
public function read($sessID)
{
@@ -91,8 +85,8 @@ class Memcache implements SessionHandlerInterface
/**
* 写入Session
* @access public
* @param string $sessID
* @param string $sessData
* @param string $sessID
* @param String $sessData
* @return bool
*/
public function write($sessID, $sessData)
@@ -103,7 +97,7 @@ class Memcache implements SessionHandlerInterface
/**
* 删除Session
* @access public
* @param string $sessID
* @param string $sessID
* @return bool
*/
public function destroy($sessID)
@@ -114,7 +108,7 @@ class Memcache implements SessionHandlerInterface
/**
* Session 垃圾回收
* @access public
* @param string $sessMaxLifeTime
* @param string $sessMaxLifeTime
* @return true
*/
public function gc($sessMaxLifeTime)

View File

@@ -11,10 +11,10 @@
namespace think\session\driver;
use SessionHandlerInterface;
use SessionHandler;
use think\Exception;
class Memcached implements SessionHandlerInterface
class Memcached extends SessionHandler
{
protected $handler = null;
protected $config = [
@@ -35,8 +35,8 @@ class Memcached implements SessionHandlerInterface
/**
* 打开Session
* @access public
* @param string $savePath
* @param mixed $sessName
* @param string $savePath
* @param mixed $sessName
*/
public function open($savePath, $sessName)
{
@@ -44,35 +44,27 @@ class Memcached implements SessionHandlerInterface
if (!extension_loaded('memcached')) {
throw new Exception('not support:memcached');
}
$this->handler = new \Memcached;
// 设置连接超时时间(单位:毫秒)
if ($this->config['timeout'] > 0) {
$this->handler->setOption(\Memcached::OPT_CONNECT_TIMEOUT, $this->config['timeout']);
}
// 支持集群
$hosts = explode(',', $this->config['host']);
$ports = explode(',', $this->config['port']);
if (empty($ports[0])) {
$ports[0] = 11211;
}
// 建立连接
$servers = [];
foreach ((array) $hosts as $i => $host) {
$servers[] = [$host, (isset($ports[$i]) ? $ports[$i] : $ports[0]), 1];
}
$this->handler->addServers($servers);
if ('' != $this->config['username']) {
$this->handler->setOption(\Memcached::OPT_BINARY_PROTOCOL, true);
$this->handler->setSaslAuthData($this->config['username'], $this->config['password']);
}
return true;
}
@@ -85,14 +77,13 @@ class Memcached implements SessionHandlerInterface
$this->gc(ini_get('session.gc_maxlifetime'));
$this->handler->quit();
$this->handler = null;
return true;
}
/**
* 读取Session
* @access public
* @param string $sessID
* @param string $sessID
*/
public function read($sessID)
{
@@ -102,8 +93,8 @@ class Memcached implements SessionHandlerInterface
/**
* 写入Session
* @access public
* @param string $sessID
* @param string $sessData
* @param string $sessID
* @param String $sessData
* @return bool
*/
public function write($sessID, $sessData)
@@ -114,7 +105,7 @@ class Memcached implements SessionHandlerInterface
/**
* 删除Session
* @access public
* @param string $sessID
* @param string $sessID
* @return bool
*/
public function destroy($sessID)
@@ -125,7 +116,7 @@ class Memcached implements SessionHandlerInterface
/**
* Session 垃圾回收
* @access public
* @param string $sessMaxLifeTime
* @param string $sessMaxLifeTime
* @return true
*/
public function gc($sessMaxLifeTime)

View File

@@ -11,10 +11,10 @@
namespace think\session\driver;
use SessionHandlerInterface;
use SessionHandler;
use think\Exception;
class Redis implements SessionHandlerInterface
class Redis extends SessionHandler
{
/** @var \Redis */
protected $handler = null;
@@ -37,38 +37,29 @@ class Redis implements SessionHandlerInterface
/**
* 打开Session
* @access public
* @param string $savePath
* @param mixed $sessName
* @param string $savePath
* @param mixed $sessName
* @return bool
* @throws Exception
*/
public function open($savePath, $sessName)
{
if (extension_loaded('redis')) {
$this->handler = new \Redis;
// 检测php环境
if (!extension_loaded('redis')) {
throw new Exception('not support:redis');
}
$this->handler = new \Redis;
// 建立连接
$func = $this->config['persistent'] ? 'pconnect' : 'connect';
$this->handler->$func($this->config['host'], $this->config['port'], $this->config['timeout']);
// 建立连接
$func = $this->config['persistent'] ? 'pconnect' : 'connect';
$this->handler->$func($this->config['host'], $this->config['port'], $this->config['timeout']);
if ('' != $this->config['password']) {
$this->handler->auth($this->config['password']);
}
if ('' != $this->config['password']) {
$this->handler->auth($this->config['password']);
}
if (0 != $this->config['select']) {
$this->handler->select($this->config['select']);
}
} elseif (class_exists('\Predis\Client')) {
$params = [];
foreach ($this->config as $key => $val) {
if (in_array($key, ['aggregate', 'cluster', 'connections', 'exceptions', 'prefix', 'profile', 'replication'])) {
$params[$key] = $val;
unset($this->config[$key]);
}
}
$this->handler = new \Predis\Client($this->config, $params);
} else {
throw new \BadFunctionCallException('not support: redis');
if (0 != $this->config['select']) {
$this->handler->select($this->config['select']);
}
return true;
@@ -83,14 +74,13 @@ class Redis implements SessionHandlerInterface
$this->gc(ini_get('session.gc_maxlifetime'));
$this->handler->close();
$this->handler = null;
return true;
}
/**
* 读取Session
* @access public
* @param string $sessID
* @param string $sessID
* @return string
*/
public function read($sessID)
@@ -101,79 +91,38 @@ class Redis implements SessionHandlerInterface
/**
* 写入Session
* @access public
* @param string $sessID
* @param string $sessData
* @param string $sessID
* @param String $sessData
* @return bool
*/
public function write($sessID, $sessData)
{
if ($this->config['expire'] > 0) {
$result = $this->handler->setex($this->config['session_name'] . $sessID, $this->config['expire'], $sessData);
return $this->handler->setex($this->config['session_name'] . $sessID, $this->config['expire'], $sessData);
} else {
$result = $this->handler->set($this->config['session_name'] . $sessID, $sessData);
return $this->handler->set($this->config['session_name'] . $sessID, $sessData);
}
return $result ? true : false;
}
/**
* 删除Session
* @access public
* @param string $sessID
* @param string $sessID
* @return bool
*/
public function destroy($sessID)
{
return $this->handler->del($this->config['session_name'] . $sessID) > 0;
return $this->handler->delete($this->config['session_name'] . $sessID) > 0;
}
/**
* Session 垃圾回收
* @access public
* @param string $sessMaxLifeTime
* @param string $sessMaxLifeTime
* @return bool
*/
public function gc($sessMaxLifeTime)
{
return true;
}
/**
* Redis Session 驱动的加锁机制
* @access public
* @param string $sessID 用于加锁的sessID
* @param integer $timeout 默认过期时间
* @return bool
*/
public function lock($sessID, $timeout = 10)
{
if (null == $this->handler) {
$this->open('', '');
}
$lockKey = 'LOCK_PREFIX_' . $sessID;
// 使用setnx操作加锁
$isLock = $this->handler->setnx($lockKey, 1);
if ($isLock) {
// 设置过期时间,防止死任务的出现
$this->handler->expire($lockKey, $timeout);
return true;
}
return false;
}
/**
* Redis Session 驱动的解锁机制
* @access public
* @param string $sessID 用于解锁的sessID
*/
public function unlock($sessID)
{
if (null == $this->handler) {
$this->open('', '');
}
$this->handler->del('LOCK_PREFIX_' . $sessID);
}
}