개발 중에 추가하거나 양식을 수정합니다. 백그라운드에서 데이터베이스 작업을 완료한 후 다른 페이지로 이동할지, 이 페이지로 돌아올지 설정합니다. 이때 브라우저의 뒤로 버튼을 클릭하고 그런 다음 페이지를 제출하거나 새로 고치면 form 양식이 반복적으로 제출됩니다. 즉, 이 레코드가 두 번 추가되거나 수정됩니다.
양식이 제출되는 이유입니다. 반복되는 것은 첫 번째 제출입니다. 양식은 메모리에 캐시되며 다음 페이지가 제출되거나 페이지가 닫히거나 자체 호출이 반환될 때까지 사라지지 않습니다. , 메모리의 데이터는 아직 남아 있습니다. 이 때 코드는 제출된 값을 감지할 수 있습니다.
: 가장 간단한 방법은 페이지를 제출한 후 이 페이지 대신 다른 페이지로 이동하는 것입니다. 페이지 주소가 http://yourdomain.com/User/Index/login
주소 형식은 오류를 반환하는 <form action="{:U('User/Index/check_login')}" method="post">
을 클릭하면 이전 주소로 돌아가지만 이 상황도 안전하지 않습니다. 또한 방법 2
방법 2: 양식을 제출한 후 제출 버튼이 회색으로 변하거나 제출 버튼이 숨겨집니다이 방법은 일반적으로 JS
를 사용하여 사용자의 클릭 동작을 동적으로 모니터링하는 방법 1과 함께 수행됩니다. , 그리고 버튼속성 을 비활성화로 설정합니다. 즉, 코드는 다음과 같습니다. :HTML:
<form action="{:U('User/Index/check_login')}" method="post">
$().ready(function(){ $("#login_btn").on('click',function(){ $(this).attr('disabled',true); }); });
방법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); }
<input type="hidden" name="TOKEN" value="{:session('TOKEN')}" />
Controller
POST 요청에서
if(IS_POST) { $post_token = I('post.TOKEN'); if(!checkToken($post_token)){ $this->error('请不要重复提交页面',U('User/Index/login')); } }
위 내용은 반복적인 양식 제출을 방지하는 방법에 대한 ThinkPHP 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!