php 防止页面刷新重复提交

本文介绍两种使用PHP通过session和token机制防止表单重复提交的方法。一种是直接在表单中加入隐藏字段并与session进行比对;另一种是通过设置和验证token来确保表单只能提交一次。

一.使用session防止重复提交 

其实跟验证码一样的原理,主要是生成session和input隐藏域,

这边我的代码是在一个页面中处理。

<?php
	header('Content-type:text/html; charset=utf-8'); //页面编码
	session_start();  //开启session

	if(isset($_POST['submit'])){ //判断是否是表单提交
		if($_SESSION['code'] != $_POST['code']){ //令牌判断
			die('重复提交');
		}
		$_SESSION['code'] = '';
		//-------------这边用于处理代码-
		die('跳转');
	}else{  
		//不是表单提交就生成code代码
		$res = md5(uniqid( rand(),false));
		$_SESSION['code'] = $res;
	}
?>

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8" />
	<title>重复提交</title>
</head>
<body>
	<form method="post" action="submit.php">
		<input type="text" name="user" />
		<input type="hidden" name="code" value="<?php echo $_SESSION['code']; ?>" />
		<input type="submit" name="submit" />
	</form>
</body>
</html>

2.下面代码是网上的

<?php  
/* 
* PHP简单利用token防止表单重复提交 
* 此处理方法纯粹是为了给初学者参考 
*/  
header('Content-type:text/html; charset=utf-8');
session_start();  
function set_token() {  
    $_SESSION['token'] = md5(microtime(true));  
}  
  
function valid_token() {  
    $return = $_REQUEST['token'] === $_SESSION['token'] ? true : false;  
    set_token();  
    return $return;  
}  
  
//如果token为空则生成一个token  
if(!isset($_SESSION['token']) || $_SESSION['token']=='') {  
    set_token();  
}  
  
if(isset($_POST['test'])){  
    if(!valid_token()){  
        echo "token error";  
    }else{  
        echo '成功提交,Value:'.$_POST['test'];  
    }  
}  
?>  
<form method="post" action="">  
    <input type="hidden" name="token" value="<?php echo $_SESSION['token']?>">  
    <input type="text" name="test" value="Default">  
    <input type="submit" value="提交" />  
</form> 




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值