PHP 中的Post-Redirect-Get (PRG) 模式:實作表單重新提交保護
設計Web 應用程式時,防止表單重新提交頁面重新載入或後退按鈕操作後可以增強使用者體驗並保持資料完整性。 Post-Redirect-Get (PRG) 模式是解決此問題的一種廣泛認可的方法,但找到簡單的 PHP 實作可能具有挑戰性。
以下是示範 PHP 中 PRG 模式的簡化範例:
<?php if ($_POST) { // Validate input if (/* Input is valid */) { // Execute code (such as database updates) here. // Redirect to this page. header("Location: {$_SERVER['REQUEST_URI']}", true, 303); exit(); } } ?> <html> <!-- Your HTML page with a form --> </html>
在此範例中,當透過 POST 提交表單時,將驗證輸入。如果輸入有效,則執行資料庫更新等代碼。隨後,該腳本使用 Location 標頭將使用者重新導向至同一頁面。 303 See Other 狀態碼表示應透過 GET 重複請求,有效防止表單重新提交。
透過使用 $_SERVER['REQUEST_URI'],此範例避免了 CMS 系統和框架中 PHP_SELF 的潛在問題。呼叫 exit() 函數是為了防止執行重定向下方的 HTML 程式碼。
此 PRG 實作提供了針對表單重新提交的保護,同時最大限度地降低了程式碼複雜性。透過採用此模式,您可以增強 Web 應用程式的穩健性和使用者體驗。
以上是PHP 中的 Post-Redirect-Get (PRG) 模式如何防止表單重新提交?的詳細內容。更多資訊請關注PHP中文網其他相關文章!