我試圖找出爲什麼當我的數據庫中存在與我的用戶名或電子郵件地址匹配時不報告驗證錯誤。當用戶名或電子郵件存在時不返回錯誤
它仍然顯示這是正確的帖子參數。它在關注焦點時確實會做兩個不同的帖子請求。
註冊控制器:
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
我有一個,但我也試圖做一個與客戶端作爲一個雙重檢查。 –