当前位置:首页 > PHP教程 > php应用 > 列表

PHP防止post重复提交数据的简单例子

发布:smiling 来源: PHP粉丝网  添加日期:2021-02-09 12:01:56 浏览: 评论:0 

这篇文章主要介绍了PHP防止post重复提交数据的简单例子,使用session记录一个数值的方法实现,需要的朋友可以参考下。

在某帝国面试的时候问题了这个题: 怎么处理post提交重复的问题, 后来跟@暖阳交流,他说记录时间,我没有明白,我想的是用session在表单页面记录下,然后提交页面判断,如果相等则视为成功,并清空session,但有个问题是如果表单页面是html的呢,乍办?要不调个php验证的页面?类似验证码的功能. 还有的说用 header头设置过期时间...但没试.以下是我php写的,经测试可用,代码如下:

  1. <?php 
  2. //开启session 
  3. session_start(); 
  4. //如果有提交标识 
  5. if(isset($_GET['action']) && $_GET['action'] === 'save'){ 
  6.  
  7.  //如果有session且跟传过来的值一样才算提交 
  8.  if(isset($_SESSION['__open_auth']) && isset($_POST['auth']) && $_SESSION['__open_auth'] == $_POST['auth']){ 
  9.   print_r($_POST); 
  10.   $_SESSION['__open_auth'] = null;//清空 
  11.  } else { 
  12.  
  13.   //走起 
  14.   header("location: post.php"); 
  15.  } 
  16.  exit(); 
  17.  
  18. //授权 
  19. $auth = $_SESSION['__open_auth'] = time(); 
  20.  
  21. ?> 
  22. <!doctype html> 
  23. <html> 
  24. <head> 
  25.  <meta charset="UTF-8"
  26.  <title>post</title> 
  27. </head> 
  28. <body> 
  29.  <form action="post.php?action=save" method="post"
  30.   <ul> 
  31.    <li> 
  32.     <input type="hidden" name="auth" value="<?php echo $auth;?>"
  33.     <input type="text" name="userName"
  34.    </li> 
  35.    <li> 
  36.     <input type="password" name="userpass"
  37.    </li> 
  38.    <li> 
  39.     <input type="submit" value="走起"
  40.    </li> 
  41.    <li> 
  42.     <?php echo time(); ?> 
  43.    </li> 
  44.   </ul> 
  45.  </form> 
  46. </body> 
  47. </html> 

Tags: PHP防止post重复提交

分享到: