|
在某帝國面試的時候問題了這個題: 怎么處理post提交重復(fù)的問題, 后來跟@暖陽交流,他說記錄時間,我沒有明白,我想的是用session在表單頁面記錄下,然后提交頁面判斷,如果相等則視為成功,并清空session,但有個問題是如果表單頁面是html的呢,乍辦?要不調(diào)個php驗證的頁面?類似驗證碼的功能. 還有的說用 header頭設(shè)置過期時間...但沒試.以下是我php寫的,經(jīng)測試可用.
復(fù)制代碼 代碼如下:
<?php
//開啟session
session_start();
//如果有提交標(biāo)識
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();
}
//授權(quán)
$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技術(shù):PHP防止post重復(fù)提交數(shù)據(jù)的簡單例子,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。