이 글에서는 ThinkPHP의 폼 반복 제출 방지 방법을 주로 소개하고, 예제 형식의 폼 반복 제출을 방지하기 위한 thinkPHP의 다양한 공통 운용 기법과 관련 주의사항을 분석해 도움이 필요한 친구들이 참고할 수 있습니다. 중복 양식 제출을 방지하는 방법의 예를 들어 ThinkPHP를 요약하고 분석합니다. 참고하실 수 있도록 자세한 내용은 다음과 같습니다.
왜 중복된 양식이 생길 수 있나요? 개발 중 데이터베이스 작업 후 신규 또는 수정된 양식이 추가되거나 수정되는 경우 백그라운드에서 완료되면 다른 페이지로 이동하거나 페이지를 새로 고치기 전에 브라우저의 뒤로 버튼을 클릭하면 양식이 반복적으로 제출됩니다. 두 번 추가되거나 수정되었습니다.
양식을 반복적으로 제출하는 이유는 처음 제출한 양식이 메모리에 캐시되어 다음에 페이지를 제출하거나 페이지를 닫거나 다른 페이지로 리디렉션할 때까지 사라지지 않기 때문입니다. 자체 호출이 반환되면 메모리의 데이터는 여전히 존재하며 페이지에 제출된 코드는 제출된 값을 계속 감지할 수 있으므로 반복 제출이 발생합니다.
어떻게 해결하나요? 온라인 솔루션과 자체 테스트를 요약하려면 다음 방법을 사용할 수 있습니다.
방법 1:가장 간단한 방법은 페이지를 제출한 후 이 페이지 대신 다른 페이지로 이동하는 것입니다. , you 페이지 주소가
http://yourdomain.com/User/Index/login인 경우 페이지의 양식 작업 주소는
780f4b3c36ad706762deaa6d9e27b237
과 같은 다른 처리 주소일 수 있습니다. 이므로 오류가 반환되거나 사용자가 뒤로 버튼을 클릭하면 이전 주소로 돌아가게 되지만 이러한 상황은 안전하지 않습니다. 함께 안전하려면 방법 2도 일치해야 합니다
방법 2:양식 제출 후 제출 버튼이 회색으로 변하거나 제출 버튼이 숨겨집니다이 방법은 일반적으로 방법 1과 결합되어 이루어지며 JS를 사용합니다. 사용자의 클릭 동작을 동적으로 모니터링하려면 버튼 속성을 비활성화(즉, 회색이고 사용할 수 없음)로 동적으로 설정하세요. 코드는 다음과 같습니다.
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% 이상 해결할 수 있지만 Liu는 여전히 여기에서 해야 합니다. 이 문제를 서버 측에서 완전히 해결하는 세 번째 방법에 대해 이야기해 보겠습니다
방법 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:
568115841160b81a8386efa13ad3ccf5페이지 표시 전 페이지 호출
if(IS_POST) { $post_token = I('post.TOKEN'); if(!checkToken($post_token)){ $this->error('请不要重复提交页面',U('User/Index/login')); } }E
creatToken()
方法生成token,在相应控制器POST请求中 使用 checkToken()
PS:
오늘 드디어 Jianshu의 마크다운 편집기를 사용하여 콘텐츠를 게시했습니다. 물론 마크다운 구문도 다루지 않았고 전체 레이아웃도 나쁘지 않고 신선했습니다.당신이 관심을 가질 만한 기사:
PHP 페이징 표시 방법 분석 [PHP 일반 페이징 클래스 php Tips
이미지 크기를 압축하고 jpg 형식으로 변환하는 방법에 대한 PHP 예제_php Tips
PDO 추상화 계층을 사용하여 쿼리 결과를 얻는 방법에 대한 PHP 예
위 내용은 반복적인 양식 제출을 방지하는 ThinkPHP 방법 예제 분석 PHP 예제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!