如何实现PHP中表单防止重复提交及处理表单过期问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计2483个文字,预计阅读时间需要10分钟。
用户提交表单时,可能因网络原因导致数据重复插入数据库,或网页被恶意刷新造成同一条记录重复。这是一个较为棘手的问题。我们可以从客户端和服务端共同着手,设置策略避免数据重复。
用户提交表单时可能因为网速的原因,或者网页被恶意刷新,致使同一条记录重复插入到数据库中,这是一个比较棘手的问题。我们可以从客户端和服务器端一起着手,设法避免同一表单的重复提交。
1.使用客户端脚本
提到客户端脚本,经常使用的是JavaScript进行常规输入验证。在下面的例子中,我们使用它处理表单的重复提交问题,请看下面的代码:
<form method=”post” name=”register” action=”test.php” enctype=”multipart/form-data”>
<input name=”text” type=”text” id=”text” />
<input name=”cont” value=”提交” type=”button” onClick=”document.register.cont.value=’正在提交,请等待…’;document.register.cont.disabled=true;document.the_form.submit();”>
</form>
当用户单击“提交”按钮后,该按钮将变为灰色不可用状态,如图5-6所示。
本文共计2483个文字,预计阅读时间需要10分钟。
用户提交表单时,可能因网络原因导致数据重复插入数据库,或网页被恶意刷新造成同一条记录重复。这是一个较为棘手的问题。我们可以从客户端和服务端共同着手,设置策略避免数据重复。
用户提交表单时可能因为网速的原因,或者网页被恶意刷新,致使同一条记录重复插入到数据库中,这是一个比较棘手的问题。我们可以从客户端和服务器端一起着手,设法避免同一表单的重复提交。
1.使用客户端脚本
提到客户端脚本,经常使用的是JavaScript进行常规输入验证。在下面的例子中,我们使用它处理表单的重复提交问题,请看下面的代码:
<form method=”post” name=”register” action=”test.php” enctype=”multipart/form-data”>
<input name=”text” type=”text” id=”text” />
<input name=”cont” value=”提交” type=”button” onClick=”document.register.cont.value=’正在提交,请等待…’;document.register.cont.disabled=true;document.the_form.submit();”>
</form>
当用户单击“提交”按钮后,该按钮将变为灰色不可用状态,如图5-6所示。

