首页 > php开发 > php中防止post提交重复数据

php中防止post提交重复数据

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

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

例子

<?php
//开启session
session_start();
//如果有提交标识
if (isset($_GET['action']) && $_GET['action'] === 'save') {
    //如果有session且跟传过来的值一样 http://www.phprm.com 才算提交
    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="1395454119">
    <input type="text" name="userName">
   </li>
   <li>
    <input type="password" name="userpass">
   </li>
   <li>
    <input type="submit" value="走起">
   </li>
   <li>
    1395454119   </li>
  </ul>
 </form>
</body>
</html>

当然还有更多更好的办法在这就不介绍了,文章最下面你感兴趣的文章中有很多相关文章。


文章链接:http://www.phprm.com/develop/59163.html

随便收藏,请保留本文地址!

标签:none

发表留言