- 2013-12-10雷军微博披露小米“魔方”项目
 - 2013-12-1012306购票首度接入支付宝 支付时间可以快至5秒
 - 2013-12-10中国移动官网显示周四接受iPhone 5s预订
 - 2013-12-0912306 App研发故事:变成开放系统 社会人员助力
 - 2013-10-15天猫“双十一”今年打通线上线下:实体店参与。
 - 2013-10-15根据专利显示iPhone将有防摔功能。
 - 2013-10-12百度或可全面收购人人网,传闻四起!
 - 2013-10-07生物密码时代何时到来?尚存隐私泄露隐忧
 - 2013-09-29国务院近日印发了上海自由贸易试验区总体方案,自贸区...
 - 2013-09-29移动医疗大潮袭来,看着是肉 咬下去是骨头。
 
php解决表单重复提交实现方法介绍
					发表于:2013-09-08|
					次阅读|
					作者:藕码网
				
				
				摘要:复提交是我们开发中会常碰到的一个问题,除了我们使用js来防止表单的重复提交,同时还可以使用php来防止重复提交。
				重复提交是我们开发中会常碰到的一个问题,除了我们使用js来防止表单的重复提交,同时还可以使用php来防止重复提交。
<?php
/*
 * php中如何防止表单的重复提交
 */
session_start();
if (empty($_SESSION['ip'])) {//第一次写入操作,判断是否记录了IP地址,以此知道是否要写入数据库
    $_SESSION['ip'] = $_SERVER['REMOTE_ADDR']; //第一次写入,为后面刷新或后退的判断做个铺垫
    //...........//写入数据库操作
} else {//已经有第一次写入后的操作,也就不再写入数据库
    echo '请不要再次刷新和后退'; //写一些已经写入的提示或其它东西
}
?>
具体原理 
session范围变量token来防止。
1. 开启session:
session_start();
2. 如果有表单提交
if (isset($token))
token以hidden的形式包含在form当中。
<input type="hidden" name="token" value="<?php echo $token; ?>" />
3. 如果是重复提交表单
if ($_SESSION["token"] != $token) {
    // 不让重复提交,在此处理
    // header("location:".$_SERVER['PHP_SELF']);
} else {
    // 正常的表单提交,在此处理
    // echo "已提交";   
}
4. 设置token值
$token = mt_rand(0,1000000); $_SESSION['token'] = $token;
注:本站部分信息可能源于互联网分享,如有侵权,请告知,我们将及时删除!
- 用户评论
 - 相关文章
 
- 
								最新评论
 
推荐文章
				- 
							1 
bash_profile和.bashr...
详细介绍bash_profile和.bashrc之间的区别。... - 
							2 
awstats的安装简易指南...
介绍awstats的安装使用,使其能快速部署。 - 
							3 
分布式监控系统gangli...
详细介绍ganglia配置过程 - 
							4 
使用IIS+Resin来配置J...
本文介绍使用IIS+Resin来配置JSP的运行环境... - 
							5 
MYSQL的主要参数设置(...
MYSQL的主要参数设置(优化) - 
							6 
Linux服务器安全小技巧...
Linux 服务器安全小技巧 
热门文章榜
				
			








