首先,对不起我的英语,我在谷歌翻译的帮助下写了这个。
我正在尝试使用 PHP 和 Ajax 制作像 Google Wave 这样的应用程序。我有一个 textarea,当用户输入内容时,页面上的 javascript 检测到oninput
并将 textarea 的内容发送到服务器,服务器将内容存储到数据库中。
我正在做的是,每次我通过 XHR 发送内容时XHR.abort()
,总是会中断之前的 XHR 请求。数据库中的数据很好,但是,有时它存储的是以前的版本。
我知道会发生这种情况,因为即使客户端已中止,PHP 也没有停止执行,有时前一个请求比上一个请求花费了更多时间并且在最后一个请求之后完成,所以我阅读了“ignore_user_abort”函数手册和“connection_aborted”,但问题仍然存在。
我创建了这个脚本来模拟这种情况,我希望当我中止连接时(按“停止”,关闭选项卡/窗口),数据库上没有任何新数据,但 5 秒后,我仍然有新数据,所以当用户中止连接时,我需要帮助来回滚事务。
这是要模拟的脚本(定义了 PDO_DSN、PDO_USER、PDO_PASS):
<?php
ignore_user_abort(true);
ob_start('ob_gzhandler');
$PDO = new PDO(PDO_DSN, PDO_USER, PDO_PASS, array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'));
$PDO->beginTransaction();
$query = $PDO->query('INSERT INTO `table` (`content`) VALUES (' . $PDO->quote('test') . ')');
sleep(5);
echo ' ';
ob_flush();
flush();
if (connection_aborted()) {
$PDO->rollBack();
exit;
}
$PDO->commit();
ob_end_flush();