前端之家收集整理的这篇文章主要介绍了
ThinkPHP防止重复提交表单的方法实例分析,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
本文实例总结分析了ThinkPHP防止重复提交表单的方法。分享给大家供大家参考,具体如下:
为什么会有表单重复的坑
在开发中,如果一个新增或修改的表单,在后台完成数据库操作后我们设定的不是跳转到其他页面,还是返回本页面,这时点击浏览器的后退再提交或刷新页面,会导致form表单重复提交,即这条记录会被增加或修改两次。
导致表单重复提交的原因是:第一次提交的表单会被缓存到内存中,直到页面下次提交或页面关闭或转向其他页面时才消失。在自调用返回时,内存中的数据依然在,这时页面中的判断提交的代码依然可以检测到提交的值,顾会产生重复提交的效果。
如何解决?
总结网上的解决办法和自己的测试,可以用以下几个办法:
最简单:
页面提交后转到另一个
页面而不是本
页面,举个栗子,比如你的
页面地址为
则该页面的表单action地址可以为另外的处理地址,如
这样报错返回,或者用户点击回退按钮,还是会回到上一个地址,不过这种情况也不保险。还要搭配方法2,一起比较保险
提交表单后提交按钮变灰/隐藏提交按钮
这种方式一般是结合方法1来做的,通过JS来动态监听用户的点击动作,动态将按钮属性置成disabeld,即为灰色不可用。代码如下:
HTML:
方法进行重复提交判断
首先,在项目的functions.PHP中添加如下方法
PHP;">
//创建TOKEN
function createToken() {
$code = chr(mt_rand(0xB0,0xF7)) . chr(mt_rand(0xA1,0xFE)) . chr(mt_rand(0xB0,0xFE)) . chr(mt_rand(0xB0,0xFE));
session('TOKEN',authcode($code));
}
//判断TOKEN
function checkToken($token) {
if ($token == session('TOKEN')) {
session('TOKEN',NULL);
return TRUE;
} else {
return FALSE;
}
}
/* 加密TOKEN */
function authcode($str) {
$key = "YOURKEY";
$str = substr(md5($str),8,10);
return md5($key . $str);
}
在表单页面form中填入以下HTML代码
HTML: