ホームページ >データベース >mysql チュートリアル >ユーザー名の可用性をチェックするときに、jQuery のリモート メソッドの検証が常に失敗するのはなぜですか?
この質問では、ユーザーは 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: <?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); ?>
元のコードはリモートを使用していましたメソッドは常に true を返し、ユーザー名が
ユーザーは 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 コード:
以上がユーザー名の可用性をチェックするときに、jQuery のリモート メソッドの検証が常に失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。