色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

PHP防止post重復提交數據的簡單例子

在某帝國面試的時候問題了這個題: 怎么處理post提交重復的問題, 后來跟@暖陽交流,他說記錄時間,我沒有明白,我想的是用session在表單頁面記錄下,然后提交頁面判斷,如果相等則視為成功,并清空session,但有個問題是如果表單頁面是html的呢,乍辦?要不調個php驗證的頁面?類似驗證碼的功能. 還有的說用 header頭設置過期時間...但沒試.以下是我php寫的,經測試可用.

復制代碼 代碼如下:
<?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>

php技術PHP防止post重復提交數據的簡單例子,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 宜兴市| 长子县| 庄河市| 灵川县| 临泽县| 铁力市| 罗源县| 沧州市| 平阴县| 铁岭市| 长春市| 金川县| 镇康县| 洞口县| 平利县| 宝应县| 建平县| 吉安县| 宝坻区| 乐平市| 澳门| 普安县| 囊谦县| 保靖县| 札达县| 漳州市| 栾川县| 安陆市| 瓮安县| 万源市| 池州市| 陈巴尔虎旗| 南靖县| 大洼县| 麟游县| 合肥市| 宁蒗| 连州市| 博爱县| 沙湾县| 凯里市|