사용자 이름 가용성을 확인하기 위한 jQuery 유효성 검사 원격 방법
jQuery Validate를 사용하면 원격을 사용하여 사용자 이름이 데이터베이스에 이미 존재하는지 확인할 수 있습니다. 방법. 예는 다음과 같습니다.
jQuery:
$("#signupForm").validate({ rules: { username: { required: true, minlength: 3, remote: { url: "check-username.php", type: "post" } } }, messages: { username: { remote: "This username is already taken! Try another." } } });
check-username.php:
<?php header('Content-type: application/json'); $username = $_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; ?>
사용자가 사용자 이름을 입력하면 jQuery는 사용자 이름과 함께 check-username.php에 요청을 보냅니다. PHP 스크립트는 사용자 이름이 데이터베이스에 존재하는지 확인합니다. 그렇다면 false를 반환하여 사용자 이름이 사용되었음을 나타냅니다. 그렇지 않으면 true를 반환합니다.
그런데 사용자가 제공한 코드에서는 사용자 이름이 있는지 확인하려고 하면 오류가 발생합니다. 오류는 다음 줄에서 발생합니다.
$check_for_username = mysql_query("SELECT username FROM mmh_user_info WHERE username='$name'");
mysql_query를 사용하는 대신 준비된 문을 사용하여 SQL 주입 공격을 방지해야 합니다.
$stmt = $mysqli->prepare("SELECT username FROM mmh_user_info WHERE username=?"); $stmt->bind_param("s", $name);
고정된 PHP 스크립트는 다음과 같습니다. :
execute()) { $stmt->store_result(); if ($stmt->num_rows() > 0) { $output = true; } else { $output = false; } } else { $output = false; } $stmt->close(); $mysqli->close(); echo json_encode($output); ?>
이제 이 스크립트는 사용자 이름이 데이터베이스에 있는지 정확하게 확인하고 jQuery에 올바른 응답을 반환해야 합니다. 확인하세요.
위 내용은 jQuery Validate의 원격 방법을 사용하여 사용자 이름 가용성을 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!