首頁  >  文章  >  後端開發  >  php防止表單重複提交的方法介紹(程式碼範例)

php防止表單重複提交的方法介紹(程式碼範例)

不言
不言轉載
2019-02-11 09:21:122487瀏覽

這篇文章帶給大家的內容是關於php防止表單重複提交的方法介紹(程式碼範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

說來慚愧,前幾天做專案的時候,出現個低階錯誤。在公司後台做表單提交,一是自己員工用,二是 html 自己寫的,沒有驗證表單重複提交,結果出錯了。寫出來記錄以便提醒自己,時刻不能疏忽。

解決方法

其實方法有很多種,只舉例幾個簡單的來說說。

框架

很多框架都有防止重複提交的功能,大家應該都有了解,這裡不再贅述。

前端

原理很簡單,使用者點擊提交之後,使用 JS 將提交按鈕置灰即可。

後端

也就是使用PHP 進行驗證,當然不限制以下幾種

Cookie

使用者提交表單到後端,在Cookie 中做標記,指定時間內重複提交無效。但是使用者禁用 Cookie 這個方法就失效了。

<?php

if (isset($_COOKIE['formFlag'])) {
    exit('error');
}

// 处理数据

// 30秒内重复提交无效
setcookie('formFlag', time(), time() + 30);

Session

展示表單頁面的時候,產生隨機數,同時儲存在 Session 中以及表單隱藏域中。第一次提交的時候,比較成功刪除 Session 中的值。

<?php

if (!isset($_SESSION['formFlag']) || $_POST['formFlag'] != $_SESSION['formFlag']) {
    exit('error');
}

// 处理数据

unset($_SESSION['formFlag']);

以上是php防止表單重複提交的方法介紹(程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除