php解决和避免form表单重复提交的几种方法
php  /  管理员 发布于 7年前   166
前言 为什么要避免form表单被重复提交呢?因为我们不想让我们的服务器重复处理没必要的数据,同时我们也是避免我们的数据库产生重复的数据,避免表单重复提交也是让我们的网站更安全的一种表现。 先看一下有哪些情况下回导致表单重复提交呢,知道哪些情况下可能会出现表单重复提交就可以从根源处理表单重复提交的情况了。 下面的情况就会导致表单重复提交: 点击提交按钮两次。 点击刷新按钮。 使用浏览器后退按钮重复之前的操作,导致重复提交表单。 使用浏览器历史记录重复提交表单。 浏览器重复的HTTP请求。 网页被恶意刷新。 下面是几种解决办法: 一:利用js设置按钮点击后变成灰色 点击完按钮之后变成灰色就不能点击了,用户需要再次提交表单的话就要刷新页面之后重新填写数据再提交了。 二:利用session 在 如果发现表单提交里没有有效的标志串,这说明表单已经被提交过了,忽略这次提交。 这使你的web应用有了更高级的 加载提交的页面时候,生成一个随机数, 存储在表单的隐藏输入框中: 在接收页面的PHP代码如下: 三:利用cookies 原理和 四:利用header函数跳转 一旦用户点击提交按钮,处理完数据后跳到其他页面 五:利用数据库来添加约束 直接在数据库里添加唯一约束或创建唯一索引,一旦发现用户重复提交了,直接抛出警告或者提示,或者只处理第一次提交的数据,这是最直接有效的方法,要求前期的数据库设计和架构要考虑周全. 六:Post/Redirect/Get模式。 在提交后执行页面重定向,这就是所谓的 总结 以上就是关于PHP解决和避免form表单重复提交的几种方法,通过以上几种方法就能避免用户按F5导致的重复提交,而其也不会出现浏览器表单重复提交的警告,也能消除按浏览器前进和后退按导致的同样问题。希望这篇文章对大家的学习和工作能带来一定的帮助。session
中放一个特殊标志。当表单页面被请求时,生成一个特殊的字符标志串,存在session
中,同时放在表单的隐藏域里。接受处理表单数据时,检查标识字串是否存在,并立即从session中删除它,然后正常处理数据。XSRF
保护$code = mt_rand(0,1000000);
< input type=”hidden” name=”code” value=””>
session
差不多,但是cookies
一旦用户浏览器禁用cookies
,这功能就失效了if(isset($_POST[‘submit'])){setcookie(“tempcookie”,””,time()+30);header(“Location:”.$_SERVER[PHP_SELF]);exit();}if(isset($_COOKIE[“tempcookie”])){setcookie(“tempcookie”,””,0);echo “您已经提交过表单”;}
if (isset($_POST[‘submit'])) {header(‘location:success.php');//处理数据后,转向到其他页面}
Post-Redirect-Get (PRG)
模式。简言之,当用户提交了表单后,你去执行一个客户端的重定向,转到提交成功信息页面。if (isset($_POST[‘action']) && $_POST[‘action'] == ‘submitted') {//处理数据,如插入数据后,立即转向到其他页面header('location:submits_success.php');}
您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号