반복적인 양식 제출을 방지하는 Thinkphp 팁
Apr 11, 2020 am 09:02 AM개발 중에 새 양식이나 수정된 양식이 추가되고 백그라운드에서 데이터베이스 작업이 완료되면 다른 페이지로 이동할지, 이 페이지로 돌아올지 설정합니다. 이때 제출하거나 새로 고치기 전에 브라우저의 뒤로 버튼을 클릭하세요. 이로 인해 양식이 반복적으로 제출됩니다. 즉, 이 레코드가 두 번 추가되거나 수정됩니다.
양식을 반복적으로 제출하는 이유는 처음 제출한 양식이 메모리에 캐시되어 다음에 페이지를 제출하거나 페이지를 닫거나 다른 페이지로 리디렉션할 때까지 사라지지 않기 때문입니다. . 자체 호출이 반환되면 메모리의 데이터는 여전히 존재하며 페이지에 제출된 코드는 제출된 값을 계속 감지할 수 있으므로 반복 제출이 발생합니다.
다음 방법을 사용하여 문제를 해결할 수 있습니다.
방법 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(){ $("#login_btn").on('click',function(){ $(this).attr('disabled',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('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); }
양식 페이지 양식 Code
HTML에 다음 HTML을 입력합니다.
<input type="hidden" name="TOKEN" value="{:session('TOKEN')}" />
페이지가 표시되기 전에 creatToken() 메서드를 호출하여 토큰을 생성하고 해당 컨트롤러 POST 요청에서 checkToken()을 사용하여 다시 제출할지 여부를 결정합니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











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

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