我正在尝试验证用户是否已经存在。用户名的错误输出始终是“此用户名已被占用。”。
jQuery 验证:
除了 uniqueUsername(required、minlength、maxlength、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());
}
});
controllers/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";
}
}
models/users.php
此函数获取数组并检查此用户名是否已存在于我的数据库中,如果存在 -> true,否则 -> false。
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;
}
}