>  기사  >  PHP 프레임워크  >  반복적인 양식 제출을 방지하는 Thinkphp 팁

반복적인 양식 제출을 방지하는 Thinkphp 팁

尚
앞으로
2020-04-11 09:02:192680검색

개발 중에 새 양식이나 수정된 ​​양식이 추가되고 백그라운드에서 데이터베이스 작업이 완료되면 다른 페이지로 이동할지, 이 페이지로 돌아올지 설정합니다. 이때 제출하거나 새로 고치기 전에 브라우저의 뒤로 버튼을 클릭하세요. 이로 인해 양식이 반복적으로 제출됩니다. 즉, 이 레코드가 두 번 추가되거나 수정됩니다.

반복적인 양식 제출을 방지하는 Thinkphp 팁

양식을 반복적으로 제출하는 이유는 처음 제출한 양식이 메모리에 캐시되어 다음에 페이지를 제출하거나 페이지를 닫거나 다른 페이지로 리디렉션할 때까지 사라지지 않기 때문입니다. . 자체 호출이 반환되면 메모리의 데이터는 여전히 존재하며 페이지에 제출된 코드는 제출된 값을 계속 감지할 수 있으므로 반복 제출이 발생합니다.

다음 방법을 사용하여 문제를 해결할 수 있습니다.

방법 1: 가장 간단한 방법: 페이지를 제출한 후 이 페이지 대신 다른 페이지로 이동합니다. 예를 들어 페이지 주소가

http://yourdomain.com/User/Index/login

인 경우 그러면 페이지의 양식 동작 주소는

<form action="{:U(&#39;User/Index/check_login&#39;)}" method="post">

와 같이 오류를 보고하고 돌아가는 또 다른 처리 주소일 수도 있고, 사용자가 뒤로 버튼을 클릭하고 여전히 이전 주소로 돌아가는 경우도 있지만 이러한 상황은 안전하지 않습니다. 함께 안전하려면 방법 2도 일치해야 합니다

방법 2: 양식 제출 후 제출 버튼이 회색으로 변합니다/제출 버튼이 숨겨집니다

이 방법은 일반적으로 방법 1과 결합되어 이루어지며 JS를 사용하여 동적으로 수행합니다. 사용자의 클릭 동작을 모니터링합니다. 버튼 속성을 disabeld로 설정합니다. 이는 회색으로 표시되어 사용할 수 없음을 의미합니다. 코드는 다음과 같습니다.

HTML:

<form action="{:U(&#39;User/Index/check_login&#39;)}" method="post">
   
   
   

JS:

$().ready(function(){
     $("#login_btn").on(&#39;click&#39;,function(){
            $(this).attr(&#39;disabled&#39;,true);
      });
});

방법 1과 방법 2를 결합하면 기본적으로 반복 제출 문제의 90% 이상을 해결할 수 있지만 Da Liu는 여전히 세 번째 방법에 대해 이야기하고 싶어합니다. , 즉 서버측에서 이 문제를 한번에 해결해 보세요

방법 3: 반복 제출 판단을 위해 임의의 TOKEN 값을 숨기는 방법을 사용합니다

먼저 프로젝트의 function.php에 다음 방법을 추가합니다.php

//创建TOKEN
function createToken() {
   $code = chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) .chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE));
   session(&#39;TOKEN&#39;, authcode($code));
}
//判断TOKEN
function checkToken($token) {
    if ($token == session(&#39;TOKEN&#39;)) {
       session(&#39;TOKEN&#39;, NULL);
       return TRUE;
    } else {
      return FALSE;
    }
}
/* 加密TOKEN */
function authcode($str) {
    $key = "YOURKEY";
    $str = substr(md5($str), 8, 10);
    return md5($key . $str);
}

양식 페이지 양식 Code

HTML에 다음 HTML을 입력합니다.

<input type="hidden" name="TOKEN" value="{:session(&#39;TOKEN&#39;)}" />

페이지가 표시되기 전에 creatToken() 메서드를 호출하여 토큰을 생성하고 해당 컨트롤러 POST 요청에서 checkToken()을 사용하여 다시 제출할지 여부를 결정합니다.

if(IS_POST)
{
$post_token = I(&#39;post.TOKEN&#39;);
  if(!checkToken($post_token)){
      $this->error(&#39;请不要重复提交页面&#39;,U(&#39;User/Index/login&#39;));
  }
}

기본적으로 이 세 가지 방법을 함께 사용하면 ThinkPHP 개발 시 반복되는 양식 제출 문제를 해결할 수 있습니다. 물론 일부 학생들은 ThinkPHP의 토큰 링 메커니즘을 사용하면 실제로는 더 간단하게 숨겨진 TP를 생성할 수 있다고 말했습니다. 필드를 기본적으로 양식에 추가한 후 숨겨진 필드가 있는지 확인합니다. 세션에 있는 값만 존재하고 일치하면 됩니다. 원칙은 방법 3과 동일합니다.

추천 튜토리얼: thinkphp 튜토리얼

위 내용은 반복적인 양식 제출을 방지하는 Thinkphp 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제