本文較為詳細的匯總了PHP防止表單重復提交的幾種常用方法,在PHP程序開發中有着很高的實用價值。具體方法如下:
1. 使用JS讓按鈕在點擊一次后禁用(disable)。采用這種方法可以防止多次點擊的發生,實現方式較簡單。
缺點是若客戶端禁止JavaScript腳本,則失效。
2. 在提交成功后執行頁面重定向(redirect)。轉到提交成功信息頁面。
特點:避免F5重復提交,消除瀏覽器前進和后退按鈕可導致的同樣問題。
3. 表單隱藏域中存放session(表單被請求時生成的標記)。采用此方法在接收表單數據后,檢查此標志值是否存在,先進行刪除,然后處理數據; 若不存在,說明已提交過,忽略本次提交。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
/*
//服務端生成隨機數存入session, 分配至表單頁
$data
[
'sess_id'
] =
$_SESSION
[
'sid'
] = mt_rand(1000, 9999);
$this
->load->view(
'form'
,
$data
);
//表單頁隱藏域存放此session值
<input type=
"hidden"
name=
"sid"
value=
"<?=$sess_id; ?>"
>
//處理
if
(
$_POST
[
'sid'
] !=
''
&&
$_POST
[
'sid'
] ==
$_SESSION
[
'sid'
])
{
unset(
$_SESSION
[
'sid'
]);
echo
'處理數據'
;
}
else
{
echo
'已提交過表單'
;
}
|
token:
防止表單重復提交的方法有很多種,那么今天就給大家介紹一種php如何有效的防止表單重復提交。
代碼非常簡單
我相信大家很聰明給大家分享一個小的demo,大家可以借鑒一下:
具體代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
<?php
/*
* 2016年9月29日08:09:13
*/
session_start();
header(
"Content-Type: text/html;charset=utf-8"
);
function
set_token() {
$_SESSION
[
'token'
] = md5(microtime(true));
}
function
valid_token() {
$return
=
$_REQUEST
[
'token'
] ===
$_SESSION
[
'token'
] ? true : false;
set_token();
return
$return
;
}
//如果token為空則生成一個token
if
(!isset(
$_SESSION
[
'token'
]) ||
$_SESSION
[
'token'
]==
''
) {
set_token();
}
if
(isset(
$_POST
[
'web'
])){
if
(!valid_token()){
echo
"token error,請不要重復提交!"
;
}
else
{
echo
'成功提交,Value:'
.
$_POST
[
'web'
];
}
}
else
{
?>
<!DOCTYPE html>
<html>
<head>
<meta charset=
"utf-8"
>
<meta name=
"viewport"
content=
"width=device-width, initial-scale=1, maximum-scale=1"
>
<title>PHP防止重復提交表單</title>
<meta name=
"keywords"
content=
"PHP"
/>
<meta name=
"description"
content=
"PHP防止重復提交表單"
/>
</head>
<body>
<div id=
"main"
>
<div
class
=
"demo"
>
<form method=
"post"
action=
""
>
<input type=
"hidden"
name=
"token"
value=
"<?php echo $_SESSION['token']?>"
>
<input type=
"text"
class
=
"input"
name=
"web"
value=
"腳本之家"
>
<input type=
"submit"
class
=
"btn"
value=
"提交"
/>
</form>
</div>
</div>
</body>
</html>
<?php }?>
|
4. 數據庫唯一索引約束(最有效的防止重復數據的方法)。