如何解决? 总结网上的解决办法和自己的测试,可以用以下几个办法: 方法1:最简单:页面提交后转到另一个页面而不是本页面,举个栗子,比如你的页面地址为 # 则该页面的表单action地址可以为另外的处理地址,如 JS: $().ready(function(){
$("#login_btn").on('click',function(){
$(this).attr('disabled',true);
});
}); 方法1+方法2 结合后,基本上90%以上的重复提交问题都能解决,但是大刘这里还是要说下第三种方法,即在服务端一劳永逸的解决这个问题 方法3:使用隐藏随机TOKEN值的方法进行重复提交判断 首先,在项目的functions.php中添加如下方法 //创建TOKEN
function createToken() {
$code = chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 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: 在页面展示前调用creatToken() 方法生成token,在相应控制器POST请求中 使用 checkToken() 进行判断是否重复提交 if(IS_POST)
{
$post_token = I('post.TOKEN');
if(!checkToken($post_token)){
$this->error('请不要重复提交页面',U('User/Index/login'));
}
} 基本上,这3个方法配合着使用,就能解决ThinkPHP开发中表单重复提交问题,当然,有同学说可以使用ThinkPHP的令牌环机制,这样其实就更简单了,TP会默认在表单中生成一个隐藏域,到时候判断这个隐藏域是否存在以及和session中的值是否想的即可,原理和方法3是一样的。 PS:今天终于把内容用简书的markdown编辑器发出来了,果然markdown语法不是盖的,整个排版都清爽了,不错不错。 相关学习推荐:编程视频
以上就是分析ThinkPHP防止重复提交表单的方法实例的详细内容,更多请关注 模板之家(www.mb5.com.cn) 其它相关文章! |