> 백엔드 개발 > PHP 튜토리얼 > jQuery Validate의 원격 방법을 사용하여 사용자 이름 가용성을 확인하는 방법은 무엇입니까?

jQuery Validate의 원격 방법을 사용하여 사용자 이름 가용성을 확인하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-20 08:16:16
원래의
713명이 탐색했습니다.

How to Use jQuery Validate's Remote Method to Check for Username Availability?

사용자 이름 가용성을 확인하기 위한 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿