网站地图    收藏   

主页 > php专栏 > php应用 >

php中防止post提交重复数据 - php高级应用

来源:自学PHP网    时间:2014-11-27 22:16 作者: 阅读:

[导读] 重复提交数据我们在应用中经常会碰到了,今天我给各位介绍利用session来防止用户不小心重复提交数据的一个例子.原理非常的简单,就是用session在表单页面记录下,然后提交页面判断,如果...

php中防止post提交重复数据

重复提交数据我们在应用中经常会碰到了,今天我给各位介绍利用session来防止用户不小心重复提交数据的一个例子.

原理非常的简单,就是用session在表单页面记录下,然后提交页面判断,如果相等则视为成功,并清空session.

例子,代码如下:

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

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论