本文较为详细的汇总了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. 数据库唯一索引约束(最有效的防止重复数据的方法)。