问题描述
我想创建一个注册系统,让用户有 120 秒的时间通过电子邮件验证他们的注册。如果用户未能及时执行此操作,则必须自动删除为此注册所做的 MysqL 条目。
编辑:Cronjob 是不可能的。 MysqL 条目需要在客户端发出注册后恰好 120 秒被删除。 cronjob 无法做到这一点。
我已经尝试过睡眠,但我无法得到我想要的结果,就像这样
<?PHP
$seconds = 0;
add();
function add() {
$seconds++;
if($seconds < 6 ) {
sleep(1);
add();
}
echo $seconds;
}
?>
没有按照我的预期工作。递归函数出于某种原因创建了一个无限循环。
有没有办法在不使用睡眠的情况下请求 PHP 在 120 秒后执行一个函数。理想情况下,用户不应该注意到后端的计时器,它根本不应该影响他。
如何实现?
解决方法
您可以在用户尝试提交验证时检查它 - 如果时间已经过去,那么您的代码可以简单地拒绝接受验证信息。您不需要定时任务来自动更新数据库。
(然后,您还可以有一个“清理”cron 作业,该作业按计划运行以删除任何未及时验证的记录。