gpt4 book ai didi

php - SessionHandlerInterface 写方法替代方案

转载 作者:行者123 更新时间:2023-11-29 03:26:38 26 4
gpt4 key购买 nike

我正在为 SessionHandlerInterface 类 使用以下写入方法:

public function write($session_id, $session_data) {
$sth = DBCxn::get()->prepare("UPDATE sessions SET session_data = ?, last_update = NOW() WHERE session_id = ?");
$sth->execute(array($session_data, $session_id));
if ($sth->rowCount() == 0) {
$sth = DBCxn::get()->prepare("INSERT INTO sessions (session_id, session_data, last_update) VALUES (?, ?, NOW())");
$sth->execute(array($session_id, $session_data));
}

问题在于,如果更新查询的session_data没有改变,rowCount()会返回0,反过来函数会尝试插入一个 session_id 已经存在并返回错误。

我想做一个选择查询来验证 session_id 是否存在的解决方案。

还有哪些替代方法可以用来解决这个问题?

最佳答案

read()write() 之前调用(在 session 开始时),您将有一个 SELECT 查询在那里。

因此,您已经知道是否应该执行 INSERTUPDATE - 只需使用一个属性作为“行存在”标志,这是您从内部设置的read(),您稍后可以在 write() 中检查它。

关于php - SessionHandlerInterface 写方法替代方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35158792/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com