我试图找出为什么当我的数据库中存在与我的用户名或电子邮件地址匹配时不报告验证错误。当用户名或电子邮件存在时不返回错误
它仍然显示这是正确的帖子参数。它在关注焦点时确实会做两个不同的帖子请求。
注册控制器:
public function is_username_available()
{
if ($this->users_model->is_username_available($this->input->post('username')))
{
return false;
}
else
{
return true;
}
}
public function is_email_available()
{
if ($this->users_model->is_email_available($this->input->post('email_address')))
{
return false;
}
else
{
return true;
}
}
register.js
rules: {
username: {
minlength: 6,
maxlength: 12,
remote: {
type: 'post',
url: 'register/is_username_available',
data: {
'username': function() { return $('#username').val(); }
},
dataType: 'json'
}
},
email_address: {
email: true,
remote: {
type: 'post',
url: 'register/is_email_available',
data: {
'email_address': function() { return $("#email_address").val(); }
},
dataType: 'json'
}
}
Users_Model:
/**
* Check if username available for registering
*
* @param string
* @return bool
*/
function is_username_available($username)
{
$this->db->select('username', FALSE);
$this->db->where('LOWER(username)=', strtolower($username));
$query = $this->db->get($this->users_table);
echo $this->db->last_query();
return $query->num_rows() == 0;
}
/**
* Check if email available for registering
*
* @param string
* @return bool
*/
function is_email_available($email)
{
$this->db->select('email', FALSE);
$this->db->where('LOWER(email)=', strtolower($email));
$query = $this->db->get($this->users_table);
return $query->num_rows() == 0;
}
你为什么不使用'callback'? – Gerep
我有一个,但我也试图做一个与客户端作为一个双重检查。 –