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

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

Apr 11, 2020 am 09:02 AM
thinkphp

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

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

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

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

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

http://yourdomain.com/User/Index/login
로그인 후 복사

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

<form action="{:U('User/Index/check_login')}" method="post">
로그인 후 복사

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

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

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

HTML:

<form action="{:U('User/Index/check_login')}" method="post">
   <input type="text" name="username" value="" id="username" />
   <input type="password" name="userpwd" id="userpwd" />
   <input type="submit" name="login_btn" id="login_btn" value="登陆"/>
</form>
로그인 후 복사

JS:

$().ready(function(){
     $(&quot;#login_btn&quot;).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 = &quot;YOURKEY&quot;;
    $str = substr(md5($str), 8, 10);
    return md5($key . $str);
}
로그인 후 복사

양식 페이지 양식 Code

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

&lt;input type=&quot;hidden&quot; name=&quot;TOKEN&quot; value=&quot;{:session(&#39;TOKEN&#39;)}&quot; /&gt;
로그인 후 복사

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

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

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

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

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

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

thinkphp 프로젝트를 실행하는 방법 thinkphp 프로젝트를 실행하는 방법 Apr 09, 2024 pm 05:33 PM

thinkphp 프로젝트를 실행하는 방법

thinkphp에는 여러 버전이 있습니다. thinkphp에는 여러 버전이 있습니다. Apr 09, 2024 pm 06:09 PM

thinkphp에는 여러 버전이 있습니다.

thinkphp를 실행하는 방법 thinkphp를 실행하는 방법 Apr 09, 2024 pm 05:39 PM

thinkphp를 실행하는 방법

thinkphp를 설치하는 방법 thinkphp를 설치하는 방법 Apr 09, 2024 pm 05:42 PM

thinkphp를 설치하는 방법

laravel과 thinkphp 중 어느 것이 더 낫나요? laravel과 thinkphp 중 어느 것이 더 낫나요? Apr 09, 2024 pm 03:18 PM

laravel과 thinkphp 중 어느 것이 더 낫나요?

개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 Nov 22, 2023 pm 12:01 PM

개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법

ThinkPHP6 데이터 암호화 및 암호 해독: 민감한 데이터 보안 보호 ThinkPHP6 데이터 암호화 및 암호 해독: 민감한 데이터 보안 보호 Aug 25, 2023 pm 10:52 PM

ThinkPHP6 데이터 암호화 및 암호 해독: 민감한 데이터 보안 보호

thinkphp 성능은 어떤가요? thinkphp 성능은 어떤가요? Apr 09, 2024 pm 05:24 PM

thinkphp 성능은 어떤가요?

See all articles