> 백엔드 개발 > PHP 튜토리얼 > PRG(Post-Redirect-Get) 패턴이 PHP에서 양식 다시 제출을 어떻게 방지할 수 있습니까?

PRG(Post-Redirect-Get) 패턴이 PHP에서 양식 다시 제출을 어떻게 방지할 수 있습니까?

Susan Sarandon
풀어 주다: 2024-12-01 03:37:09
원래의
207명이 탐색했습니다.

How Can the Post-Redirect-Get (PRG) Pattern Prevent Form Resubmission in PHP?

PHP의 PRG(Post-Redirect-Get) 패턴: 양식 재제출 보호 달성

웹 애플리케이션 설계 시 양식 재제출 방지 페이지를 다시 로드하거나 뒤로 버튼 작업을 수행하면 사용자 경험이 향상되고 데이터 무결성이 유지될 수 있습니다. PRG(Post-Redirect-Get) 패턴은 이 문제를 해결하기 위해 널리 알려진 접근 방식이지만 간단한 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 구현은 코드 복잡성을 최소화하면서 양식 다시 제출을 방지합니다. 이 패턴을 사용하면 웹 애플리케이션의 견고성과 사용자 경험을 향상시킬 수 있습니다.

위 내용은 PRG(Post-Redirect-Get) 패턴이 PHP에서 양식 다시 제출을 어떻게 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿