개발 중에 새 양식이나 수정된 양식이 추가되고 백그라운드에서 데이터베이스 작업이 완료되면 다른 페이지로 이동할지, 이 페이지로 돌아올지 설정합니다. 이때 제출하거나 새로 고치기 전에 브라우저의 뒤로 버튼을 클릭하세요. 이로 인해 양식이 반복적으로 제출됩니다. 즉, 이 레코드가 두 번 추가되거나 수정됩니다.
양식을 반복적으로 제출하는 이유는 처음 제출한 양식이 메모리에 캐시되어 다음에 페이지를 제출하거나 페이지를 닫거나 다른 페이지로 리디렉션할 때까지 사라지지 않기 때문입니다. . 자체 호출이 반환되면 메모리의 데이터는 여전히 존재하며 페이지에 제출된 코드는 제출된 값을 계속 감지할 수 있으므로 반복 제출이 발생합니다.
다음 방법을 사용하여 문제를 해결할 수 있습니다.
방법 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">
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!