jQuery Validate 원격 방법: 사용자 이름 확인 문제 해결
jQuery Validate의 원격 방법을 사용하여 데이터베이스에 사용자 이름이 있는지 확인하는 경우 특정 시나리오 잘못된 오류 메시지가 나타날 수 있습니다. 이 문서에서는 사용자 이름이 존재하지 않음에도 불구하고 "이 사용자 이름은 이미 사용 중입니다"라는 오류 메시지가 표시되는 일반적인 문제를 해결합니다.
원격 방법 이해
원격 방법 서버측 스크립트에서 검색된 데이터에 대해 필드의 유효성을 검사할 수 있습니다. 두 가지 매개변수를 사용합니다:
구현예
제공된 코드에서 다음 jQuery 스크립트는 사용자 이름 필드 유효성 검사:
$("#signupForm").validate({ rules: { username: { required: true, minlength: 3, remote: "check-username.php" } }, messages: { username: { remote: "This username is already taken! Try another." } } });
check-username.php 스크립트는 POST 요청에서 사용자 이름을 검색하고 해당 사용자 이름이 데이터베이스에 존재하는지 확인합니다.
<?php require_once "./source/includes/data.php"; header('Content-type: application/json'); $name = mysql_real_escape_string($_POST['username']); $check_for_username = mysql_query("SELECT username FROM mmh_user_info WHERE username='$name'"); if (mysql_num_rows($check_for_username) > 0) { $output = true; } else { $output = false; } echo json_encode($output); ?>
문제 해결
원본 PHP 스크립트는 사용자 이름이 존재함을 나타내기 위해 true를 반환했지만, 결과를 에코하여 jQuery Validate가 잘못된 오류 메시지를 표시하게 했습니다.
수정된 PHP 스크립트는 다음과 같습니다.
<?php require_once "./source/includes/data.php"; header('Content-type: application/json'); $request = $_REQUEST['username']; $query = mysql_query("SELECT * FROM mmh_user_info WHERE username ='$username'"); $result = mysql_num_rows($query); if ($result == 0) { $valid = 'true'; } else { $valid = 'false'; } echo $valid; ?>
PHP에서 부울 값 true 또는 false만 반환하여 스크립트를 사용하면 이제 jQuery Validate에서 사용자 이름이 존재하는지 정확하게 확인할 수 있습니다.
위 내용은 내 jQuery 유효성 검사 원격 메서드에 잘못된 사용자 이름 가용성 오류가 표시되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!