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為空則生成一個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. 數據庫唯一索引約束(最有效的防止重復數據的方法)。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM