首頁  >  文章  >  後端開發  >  關於PHP使用token防止表單重複提交的方法

關於PHP使用token防止表單重複提交的方法

墨辰丷
墨辰丷原創
2018-06-04 10:07:391536瀏覽

這篇文章主要介紹了PHP使用token防止表單重複提交的方法,透過產生一個加密後的隨機數存入session的token變數,同時將該值放入表單隱藏提交,達到防止表單重複提交的功能,需要的朋友可以參考下

<?php
/*
* PHP使用token防止表单重复提交
* 此处理方法纯粹是为了给初学者参考
*/
session_start();
function set_token() {
  $_SESSION[&#39;token&#39;] = md5(microtime(true));
}
function valid_token() {
  $return = $_REQUEST[&#39;token&#39;] === $_SESSION[&#39;token&#39;] ? true : false;
  set_token();
  return $return;
}
//如果token为空则生成一个token
if(!isset($_SESSION[&#39;token&#39;]) || $_SESSION[&#39;token&#39;]==&#39;&#39;) {
  set_token();
}
if(isset($_POST[&#39;test&#39;])){
  if(!valid_token()){
    echo "token error";
  }else{
    echo &#39;成功提交,Value:&#39;.$_POST[&#39;test&#39;];
  }
}
?>
<form method="post" action="">
  <input type="hidden" name="token" value="<?php echo $_SESSION[&#39;token&#39;]?>">
  <input type="text" name="test" value="Default">
  <input type="submit" value="提交" />
</form>

總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。

相關推薦:

PHP下載檔案的函數實例詳解

PHP使用header方式實作檔案下載功能

PHP基於QRCODE產生彩色二維碼的方法

以上是關於PHP使用token防止表單重複提交的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn