我试图验证用户是否已经存在与否。用户名的错误输出始终为“此用户名已被占用。”。jQuery.validator.addMethod总是在CodeIgniter中返回true
jQuery验证:
所有验证错误的工作除了uniqueUsername(需要使用MINLENGTH,最大长度,lettersonly工作正常)。
jQuery.validator.addMethod("lettersonly", function(value, element) {
return this.optional(element) || /^[a-z]+$/i.test(value);
}, "Please enter only letters");
$.validator.addMethod("uniqueUsername", function(value, element) {
$.ajax({
type : "POST",
url : "<?php echo base_url();?>user/check_user",
data : "username=" + value,
dataType : "html",
success : function(msg) {
if (msg == 'true') {
return true;
} else {
return false;
}
}
})
}, "This username is already taken.");
$("#form").validate({
rules : {
username : {
required : true,
minlength : 3,
maxlength : 25,
lettersonly : true,
uniqueUsername : true
},
},
messages : {
username : {
required : "Username is required.",
},
},
errorElement : "span",
errorPlacement : function(error, element) {
error.appendTo(element.parent());
}
});
控制器/ user.php的:
函数check_user()发送的用户名中的阵列,以我的模型的用户。我已经测试过这个功能,它的工作原理应该是这样的。
public function check_user() {
$this -> load -> model('users');
$user = array('username' => $this -> input -> post('username'));
if ($this -> users -> is_user_username($user)) {
echo "true";
} else {
echo "false";
}
}
型号/ users.php
这个函数接受阵列并检查该用户名在我的数据库已经存在,如果是这样 - > true,否则 - >假。
public function is_user_username($user) {
$this -> db -> where('username', $user['username']);
$query = $this -> db -> get('users');
if ($query -> num_rows() == 1) {
return true;
} else {
return false;
}
}