我有一个注册表单,我在其中添加了一个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;
我还试图通过网址直接传递电子邮件的价值,因为这个价值没有被传递到'emailcheck.php'的可能性
email: {
required: true,
email: true,
remote:"emailcheck.php?email=test@test.com"
},
但我的表格仍无效。
我很欣赏我的问题。
谢谢!
答案 0 :(得分: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
。
答案 1 :(得分:0)
首先检查控制台中的js错误,如果没有错,请检查脚本发送的内容以及他从php收到的内容
答案 2 :(得分: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';
不回应错误;或回声真实; !!!