【发布时间】:2019-04-30 16:18:45
【问题描述】:
我想用 ajax 验证登录表单。我正在使用带有回调函数的表单验证来检查数据库中的用户名。当我使用带有 set_message 的回调时,表单验证错误不起作用,只显示该回调错误消息。如果用户名为空,则应首先显示“需要用户名”等表单验证错误,然后如果用户输入错误的用户名,则应显示“用户名不正确”等回调函数错误
以下是我的控制器中的功能
public function validate_form()
{
$data = array('success' => false, 'messages' => array());
$this->form_validation->set_rules('username', 'Username', 'required|trim|xss_clean|callback_username_check');
$this->form_validation->set_rules('password', 'Password', 'required|trim|xss_clean|callback_password_check');
$this->form_validation->set_error_delimiters('<p class="text-danger">', '</p>');
if ($this->form_validation->run()) {
$data['success'] = true;
$this->session->set_userdata('admin_username', $this->input->post('username'));
} else {
foreach ($_POST as $key => $value) {
$data['messages'][$key] = form_error($key);
}
}
echo json_encode($data);
}
public function username_check()
{
$username = $this->input->post("username");
if ($this->admin_model->usernameDB()) {
return true;
} else {
$this->form_validation->set_message('username_check', 'The {field} is not correct');
return false;
}
}
public function password_check()
{
$password = $this->input->post("password");
if ($this->admin_model->passwordDB($password)) {
return true;
} else {
$this->form_validation->set_message('password_check', 'The {field} is not correct');
return false;
}
}
以下是我模型中的功能
public function usernameDB() {
$this->db->where('username', $this->input->post('username'));
$query = $this->db->get('adminuser');
if ($query->num_rows() == 1) {
return true;
} else {
return false;
}
}
public function passwordDB() {
$this->db->where('password', md5($this->input->post('password')));
$query = $this->db->get('adminuser');
if ($query->num_rows() == 1) {
return true;
} else {
return false;
}
}
以下是我正在使用的 ajax
$("#admin_login_form").submit(function(e) {
e.preventDefault();
var me = $(this);
// perform ajax
$.ajax ({
url: "validate_form",
type: "post",
data: me.serialize(),
dataType: "json",
success: function(response) {
if (response.success == true) {
$('.form-group').removeClass('has-error')
.removeClass('has-success');
$('.text-danger').remove();
window.location = "member";
} else {
$.each(response.messages, function(key, value) {
var element = $('#' + key);
element.closest('div.form-group')
.removeClass('has-error')
.addClass(value.length > 0 ? 'has-error' : 'has-success')
.find('.text-danger')
.remove();
element.after(value);
});
}
}
});
});
我想要正确的验证错误顺序,例如如果用户名或密码为空,则首先应显示其相关错误,例如需要用户名或密码,然后应显示错误或正确的用户名或密码错误。
【问题讨论】:
-
xss_clean不是 CodeIgniter 版本 >= 3.0.0 的有效规则 -
我不明白什么不起作用。
-
你试过dfriend的建议了吗?此外,最好在
required之前使用trim,例如trim|required|your_callback。我也从未见过,在任何身份验证系统中,检查数据库中是否已经存在密码。我建议反对它,我强烈建议不要使用md5,而是使用password_hash和password_verify。 MD5 不安全,因为它很容易被 phps 自己的帐户破解:php.net/manual/en/function.md5.php -
我已经用截图更新了我的问题,当两个字段都为空时,应该显示必填错误。
-
是的,我正在使用带有 ajax 的表单验证,如果我删除回调函数,那么所需的工作但与回调一起,只打印回调消息,我想要两个表单验证
标签: codeigniter