如何解决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 作业,该作业按计划运行以删除任何未及时验证的记录。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。