1

我有一个注册表单,我在其中添加了一个 JQuery 验证插件远程验证。远程验证的目的是检查用户输入的电子邮件/和用户名是否已经存在于我的数据库中(即已经在使用中),并且将如果是,则返回错误消息。在我添加远程验证之前,表单正在工作。

现在,即使我输入的所有数据都是正确的,我也无法提交表单,而且为了雪上加霜,当我输入数据库中已经存在的电子邮件时,不会出现错误消息。

我的 jQuery 代码:

    $(document).ready(function(){
<!--AJAX Call to retrieve type & subtype of industries-->
    $("#type").load("getregtype.php");

    $('#type').change(function(){
        var type=$('#type').val();
        $('#subtype').load('getregsubtype.php?type='+type);
    });
<!--End of AJAX Call -->

<!--JQuery validation of registration form-->
<!--Set default message for 'equalTo' errors-->
$.extend($.validator.messages, { equalTo: "The values you entered do not match." });
    $("#regform").validate({

        // Specify the validation rules
        rules: {
            username: "required",

            password: {
                required:true,
                minlength:6,
            },

            cpassword: {
                required: true,
                minlength: 6,
                equalTo: "#password"
            },  

            email: {
                required: true,
                email: true,
                remote:"emailcheck.php"
            },

            cemail: {
                required: true,
                email: true,
                equalTo:"#email"

            },

            type: {
                required: true
            },

            subtype: {
                required: true
            },
            name: "required"
        },

        // Specify the validation error messages
        messages: {
            username: "Please enter a username",
            email: {
                required:"Please enter an email address",
                email:"Please enter a valid email address",
                remote:jQuery.format("{0} is already in use")
            },
            cemail: {
                required:"Please enter an email address",
                email:"Please reenter your email address",

            },

            password: {
                required: "Please enter a password",
                minlength: "Your password must be at least 6 characters long"
            },
            cpassword: {
                required:"Please reenter your password",
                minlength: "Your password must be at least 6 characters long"

            },
            name: "Please enter the name of your business"
        },

        submitHandler: function(form) {
            form.submit();
        }
    });


});

我的 PHP 页面被远程调用。

 <?php

include("cxn.inc");

$query=$cxn->prepare("SELECT * FROM `testdb`.`business` WHERE `Email` = :email");
$query->bindValue(":email",$_GET['email']);
$query->execute();
$count=$query->rowCount();
$mail=$_GET['email'];
print_r($mail);
echo"$count";
if($count>0)
{

    echo json_encode('false');

}
else
{
    echo json_encode('true');
}

?>

尝试过的事情

print_r($mail) 和 echo"$count"; 两者都返回正确的值。我也试过

echo json_encode(true);

return true;

编辑

我尝试了更多的东西。

echo true;

我还尝试通过 url 直接传递电子邮件的值,如果该值没有被传递给'emailcheck.php'

email: {
            required: true,
            email: true,
            remote:"emailcheck.php?email=test@test.com"
        },

但我的表格仍然不起作用。

我感谢对我的问题的任何见解。

谢谢!

4

3 回答 3

3

您的 PHP 脚本需要一个名称为 email 的 GET 参数。只是为了消除这里出现错误的可能性,您可以在 jQuery 代码中明确设置:

    rules: {
        /* Code skipped ... */

        email: {
            required: true,
            email: true,
            type: "get",
            remote:"emailcheck.php"
            data: {
                email: function() {
                           return $("#email").val();
                       }
            }
        },
        /* ... */

确保它$('#email')确实与您的表单输入相匹配。

您还可以使用 Firebug 或等效工具检查响应(只需在浏览器窗口上按 F12 并查看出现了什么),您可能需要确保响应的 mimetype 是application/json.

于 2013-08-11T09:53:22.663 回答
0
            remote: {
                url: "check-email.php",
                type: "post",
                data: {
                    email: function() {
                        return $("[name='email']").val();
                    }
                }
            }

并从 PHP 文件 check-email.php 中回显 true 或 false ,如下所示:

echo 'false';

或者

 echo 'true';

不回声假;或回声真实;!!!

于 2013-10-01T00:00:16.453 回答
0

首先检查控制台中的 js 错误,如果没有错误,还要检查你的脚本发送的内容以及他从 php 收到的内容

于 2013-08-11T09:39:37.240 回答