PHP如何防止post重复提交数据 实例代码

发布时间:2020-03-22编辑:脚本学堂
本文介绍了PHP防止post重复提交数据方法,采用session记录一个数值的方法加以实现,感兴趣的朋友参考下。

在php中防止post重复提交数据,一开始想的是用session在表单页面记录下,然后提交页面判断,如果相等则视为成功,并清空session。
但如果表单页面是html,怎么实现呢?需要高用php验证页面?类似验证码的功能。
还有的说用 header头设置过期时间。

这里分享一例php防止post重复提交数据的方法,大家做个参考。
 

复制代码 代码示例:
<?php
//开启session
session_start();
//如果有提交标识
if(isset($_GET['action']) && $_GET['action'] === 'save'){
 //如果有session且跟传过来的值一样才算提交
 if(isset($_SESSION['__open_auth']) && isset($_POST['auth']) && $_SESSION['__open_auth'] == $_POST['auth']){
  print_r($_POST);
  $_SESSION['__open_auth'] = null;//清空
 } else {
  //走起
  header("location: post.php");
 }
 exit();
}
//授权
$auth = $_SESSION['__open_auth'] = time();
?>
<!doctype html>
<html>
<head>
 <meta charset="UTF-8">
 <title>post</title>
</head>
<body>
 <form action="post.php?action=save" method="post">
  <ul>
   <li>
    <input type="hidden" name="auth" value="<?php echo $auth;?>">
    <input type="text" name="userName">
   </li>
   <li>
    <input type="password" name="userpass">
   </li>
   <li>
    <input type="submit" value="走起">
   </li>
   <li>
    <?php echo time(); ?>
   </li>
  </ul>
 </form>
</body>
</html>