使用Session限制表单提交的时间

use*_*850 7 php

我花了2个多小时在网上搜寻,试图解决这个问题.我试图以超过60秒的速度停止多个表单提交.这是我正在使用的.

session_start();
if (!isset($_SESSION['last_submit']))
    $_SESSION['last_submit'] = time();

if (time()-$_SESSION['last_submit'] < 60)
    die('Post limit exceeded. Please wait at least 60 seconds');
else
    $_SESION['last_submit'] = time();
Run Code Online (Sandbox Code Playgroud)

我在网站上发现了这一点,但是到目前为止还没能找到其他任何东西.我在开头的页面上有一些代码,用以前的页面POST结果进行数据库查询.我需要设置$last_submit一定值吗?任何帮助表示赞赏.

MrC*_*ode 7

你有两个问题.首先,在第一次执行时,您将会话值设置为time(),因此第一次尝试将始终产生超出限制的错误.第二个问题是你有一个错字$_SESION.

尝试:

session_start();

if (isset($_SESSION['last_submit']) && time()-$_SESSION['last_submit'] < 60)
    die('Post limit exceeded. Please wait at least 60 seconds');
else
    $_SESSION['last_submit'] = time();
Run Code Online (Sandbox Code Playgroud)

此外,应该注意的是,这不是万无一失的,因为用户可以拒绝cookie或删除会话cookie,以绕过您的支票.