PHP防止表单重复提交的几种常用方法汇总
本文较为详细的汇总了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为空则生成一个tokenif(!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. 数据库唯一索引约束(最有效的防止重复数据的方法)。

浙公网安备 33010602011771号