PHP實現(xiàn)防止表單重復提交功能【基于token驗證】
本文實例講述了PHP實現(xiàn)防止表單重復提交功能。分享給大家供大家參考,具體如下:
防止表單重復提交的方法有很多種,那么今天就給大家介紹一種php如何有效的防止表單重復提交。
代碼非常簡單
我相信大家很聰明給大家分享一個小的demo,大家可以借鑒一下:


具體代碼:
<?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 }?>
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php程序設計安全教程》、《php安全過濾技巧總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
PHP使用pdo連接access數(shù)據(jù)庫并循環(huán)顯示數(shù)據(jù)操作示例
這篇文章主要介紹了PHP使用pdo連接access數(shù)據(jù)庫并循環(huán)顯示數(shù)據(jù)操作,結合實例形式較為詳細的分析了php使用pdo進行access數(shù)據(jù)庫連接、查詢、執(zhí)行sql語句、預處理等相關操作技巧與注意事項,需要的朋友可以參考下2018-06-06
php mysql procedure實現(xiàn)獲取多個結果集的方法【基于thinkPHP】
這篇文章主要介紹了php mysql procedure實現(xiàn)獲取多個結果集的方法,基于thinkPHP實現(xiàn)針對數(shù)據(jù)庫多個結果集的相關操作技巧,需要的朋友可以參考下2016-11-11
關于使用key/value數(shù)據(jù)庫redis和TTSERVER的心得體會
本篇文章是對使用key/value數(shù)據(jù)庫redis和TTSERVER的心得體會進行了詳細的分析介紹,需要的朋友參考下2013-06-06
php Smarty date_format [格式化時間日期]
php Smarty date_format [格式化時間日期] ,需要的朋友可以參考下。2010-03-03

