>  기사  >  백엔드 개발  >  반복적인 양식 제출을 방지하는 방법에 대한 ThinkPHP 팁

반복적인 양식 제출을 방지하는 방법에 대한 ThinkPHP 팁

PHPz
PHPz원래의
2017-04-04 15:03:251286검색

왜 중복된 양식이 있나요?

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

양식이 제출되는 이유입니다. 반복되는 것은 첫 번째 제출입니다. 양식은 메모리에 캐시되며 다음 페이지가 제출되거나 페이지가 닫히거나 자체 호출이 반환될 때까지 사라지지 않습니다. , 메모리의 데이터는 아직 남아 있습니다. 이 때 코드는 제출된 값을 감지할 수 있습니다.

요약하자면? 온라인 솔루션과 자체 테스트를 수행하려면 다음 방법을 사용할 수 있습니다.

방법 1

: 가장 간단한 방법은 페이지를 제출한 후 이 페이지 대신 다른 페이지로 이동하는 것입니다. 페이지 주소가

http://yourdomain.com/User/Index/login
인 경우 페이지의

action

주소 형식은 오류를 반환하는

<form action="{:U(&#39;User/Index/check_login&#39;)}" method="post">
와 같은 다른 처리 주소일 수 있습니다. 사용자가 뒤로

버튼

을 클릭하면 이전 주소로 돌아가지만 이 상황도 안전하지 않습니다. 또한 방법 2

방법 2: 양식을 제출한 후 제출 버튼이 회색으로 변하거나 제출 버튼이 숨겨집니다

이 방법은 일반적으로 JS

를 사용하여 사용자의 클릭 동작을 동적으로 모니터링하는 방법 1과 함께 수행됩니다. , 그리고 버튼

속성 을 비활성화로 설정합니다. 즉, 코드는 다음과 같습니다. :HTML:

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

$().ready(function(){
     $("#login_btn").on('click',function(){
            $(this).attr('disabled',true);
      });
});
방법 1 + 방법 2 결합하면 기본적으로 중복 제출 문제는 90% 이상 해결이 가능하지만 Liu는 여기서 이 문제를 서버에서 한번에 해결하는 세 번째 방법에 대해 이야기하겠습니다. side

방법3

: 무작위 TOKEN 값을 숨기는 방법을 사용하여 반복 제출 여부를 판단

먼저 프로젝트의 function.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('TOKEN', authcode($code));
}
//判断TOKEN
function checkToken($token) {
    if ($token == session('TOKEN')) {
       session('TOKEN', NULL);
       return TRUE;
    } else {
      return FALSE;
    }
}
/* 加密TOKEN */
function authcode($str) {
    $key = "YOURKEY";
    $str = substr(md5($str), 8, 10);
    return md5($key . $str);
}
양식 페이지 양식에 다음 HTML 코드를 입력합니다.

HTML:

<input type="hidden" name="TOKEN" value="{:session(&#39;TOKEN&#39;)}" />
페이지가 표시되기 전에 creatToken을 호출합니다() 메서드가 토큰을 생성하고 checkToken()을 사용합니다. 해당

Controller

POST 요청에서

if(IS_POST)
{
$post_token = I('post.TOKEN');
  if(!checkToken($post_token)){
      $this->error('请不要重复提交页面',U('User/Index/login'));
  }
}
를 다시 제출할지 여부를 결정합니다. 기본적으로 이 세 가지 방법을 함께 사용하면 반복적인 양식 제출 문제를 해결할 수 있습니다. 물론 ThinkPHP 개발에서 일부 학생들은 실제로 더 간단한 ThinkPHP의 토큰 링 메커니즘을 사용할 수 있다고 말했습니다. TP는 기본적으로 숨겨진 필드를 생성한 다음 숨겨진 필드를 결정합니다. 존재하는지, 세션에 있는 값과 일치하는지 여부는 방법 3과 동일합니다.

반복적인 양식 제출을 방지하는 방법에 대한 ThinkPHP 팁

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

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