PHP 后端如何在 x 秒后删除 MySql 条目?

问题描述

我想创建一个注册系统,让用户有 120 秒的时间通过电子邮件验证他们的注册。如果用户未能及时执行此操作,则必须自动删除为此注册所做的 MysqL 条目。

编辑:Cronjob 是不可能的。 MysqL 条目需要在客户端发出注册后恰好 120 秒被删除。 cronjob 无法做到这一点。

我已经尝试过睡眠,但我无法得到我想要的结果,就像这样

<?PHP
$seconds = 0;
add();
function add() {
    $seconds++;
    if($seconds < 6 ) {
        sleep(1);
        add();
    }   
    echo $seconds;
}
?>

没有按照我的预期工作。递归函数出于某种原因创建了一个无限循环。

有没有办法在不使用睡眠的情况下请求 PHP 在 120 秒后执行一个函数。理想情况下,用户不应该注意到后端的计时器,它根本不应该影响他。

如何实现?

解决方法

您可以在用户尝试提交验证时检查它 - 如果时间已经过去,那么您的代码可以简单地拒绝接受验证信息。您不需要定时任务来自动更新数据库。

(然后,您还可以有一个“清理”cron 作业,该作业按计划运行以删除任何未及时验证的记录。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...