ThinkPHP防止重复提交表单的方法实例分析


Posted in PHP onMay 10, 2018

本文实例总结分析了ThinkPHP防止重复提交表单的方法。分享给大家供大家参考,具体如下:

为什么会有表单重复的坑

在开发中,如果一个新增或修改的表单,在后台完成数据库操作后我们设定的不是跳转到其他页面,还是返回本页面,这时点击浏览器的后退再提交或刷新页面,会导致form表单重复提交,即这条记录会被增加或修改两次。

导致表单重复提交的原因是:第一次提交的表单会被缓存到内存中,直到页面下次提交或页面关闭或转向其他页面时才消失。在自调用返回时,内存中的数据依然在,这时页面中的判断提交的代码依然可以检测到提交的值,顾会产生重复提交的效果。

如何解决?

总结网上的解决办法和自己的测试,可以用以下几个办法:

方法1:最简单:页面提交后转到另一个页面而不是本页面,举个栗子,比如你的页面地址为

http://yourdomain.com/User/Index/login

则该页面的表单action地址可以为另外的处理地址,如

<form action="{:U('User/Index/check_login')}" method="post">

这样报错返回,或者用户点击回退按钮,还是会回到上一个地址,不过这种情况也不保险。还要搭配方法2,一起比较保险

方法2:提交表单后提交按钮变灰/隐藏提交按钮

这种方式一般是结合方法1来做的,通过JS来动态监听用户的点击动作,动态将按钮属性置成disabeld,即为灰色不可用。代码如下:

HTML:

<form action="{:U('User/Index/check_login')}" method="post">
  <input type="text" name="username" value="" id="username" />
  <input type="password" name="userpwd" id="userpwd" />
  <input type="submit" name="login_btn" id="login_btn" value="登陆"/>
</form>

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:

<input type="hidden" name="TOKEN" value="{:session('TOKEN')}" />

在页面展示前调用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框架的PHP程序设计有所帮助。

PHP 相关文章推荐
php读取msn上的用户信息类
Dec 05 PHP
关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况
Jan 06 PHP
php中选择什么接口(mysql、mysqli)访问mysql
Feb 06 PHP
PHP数据类型之布尔型的介绍
Apr 28 PHP
PHP中如何实现常用邮箱的基本判断
Jan 07 PHP
php实现插入排序
Mar 29 PHP
PHP中static关键字以及与self关键字的区别
Jul 01 PHP
PHP读书笔记整理_结构语句详解
Jul 01 PHP
php版微信公众平台接口参数调试实现判断用户行为的方法
Sep 23 PHP
ThinkPHP打水印及设置水印位置的方法
Oct 14 PHP
PHP pthreads v3在centos7平台下的安装与配置操作方法
Feb 21 PHP
PHP如何解决微信文章图片防盗链
Dec 09 PHP
PHP实现用户登录的案例代码
May 10 #PHP
yii2多图上传组件的使用教程
May 10 #PHP
PHP数组去重的更快实现方式分析
May 09 #PHP
PHP+MySQL实现消息队列的方法分析
May 09 #PHP
PHP共享内存使用与信号控制实例分析
May 09 #PHP
php curl批处理实现可控并发异步操作示例
May 09 #PHP
php使用curl伪造来源ip和refer的方法示例
May 08 #PHP
You might like
全国FM电台频率大全 - 23 四川省
2020/03/11 无线电
在普通HTTP上安全地传输密码
2007/07/21 PHP
Zend Framework教程之视图组件Zend_View用法详解
2016/03/05 PHP
如何让动态插入的javascript脚本代码跑起来。
2007/01/09 Javascript
由document.body和document.documentElement想到的
2009/04/13 Javascript
JQuery Ajax 跨域访问的解决方案
2010/03/12 Javascript
12个非常有创意的JavaScript小游戏
2010/03/18 Javascript
js 获取、清空input type=&quot;file&quot;的值示例代码
2014/02/19 Javascript
JavaScript window.location对象
2014/11/14 Javascript
JavaScript中split() 使用方法汇总
2015/04/17 Javascript
基于jQuery实现的QQ表情插件
2015/08/25 Javascript
Bootstrap组件(一)之菜单
2016/05/11 Javascript
简单实现js轮播图效果
2017/07/14 Javascript
vuex页面刷新后数据丢失的方法
2019/01/17 Javascript
JavaScript中0、空字符串、'0'是true还是false的知识点分享
2019/09/16 Javascript
在vue项目中 实现定义全局变量 全局函数操作
2020/10/26 Javascript
[42:52]IG vs VGJ.T 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
Python基于pygame实现的font游戏字体(附源码)
2015/11/11 Python
使用PyCharm创建Django项目及基本配置详解
2018/10/24 Python
在python2.7中用numpy.reshape 对图像进行切割的方法
2018/12/05 Python
Django 源码WSGI剖析过程详解
2019/08/05 Python
django-filter和普通查询的例子
2019/08/12 Python
淘宝秒杀python脚本 扫码登录版
2019/09/19 Python
如何基于python操作excel并获取内容
2019/12/24 Python
使用python计算三角形的斜边例子
2020/04/15 Python
在pycharm中debug 实时查看数据操作(交互式)
2020/06/09 Python
mac系统下安装pycharm、永久激活、中文汉化详细教程
2020/11/24 Python
CSS3实现的炫酷菜单代码分享
2015/03/12 HTML / CSS
法国最大电子商务平台:Cdiscount
2018/03/13 全球购物
美国男士和女士奢侈品折扣手表购物网站:Certified Watch Store
2018/06/13 全球购物
匈牙利超级网上商店和优惠:Alza.hu
2019/12/17 全球购物
计算机大学生的自我评价
2013/10/15 职场文书
2014小学年度工作总结
2014/12/20 职场文书
2016年教师节感言
2015/12/09 职场文书
反邪教教育心得体会
2016/01/15 职场文书
奥特曼十大神器:奥特手镯在榜,第一是贝利亚的神器
2022/03/18 日漫