codeigniter - Codeigniter 3 验证错误未与回调函数一起显示
问题描述
我想用 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);
});
}
}
});
});
我想要正确的验证错误顺序,例如如果用户名或密码为空,则首先应显示其相关错误,例如需要用户名或密码,然后应显示错误或正确的用户名或密码错误。
解决方案
你可以试试下面。您可以使用单个回调函数来检查用户是否存在。
首先,从您的控制器中删除回调函数public function username_check()
并public function password_check()
替换为下面的更新函数。
除了这个创建的新模型函数之外login
,admin_model
它将检查用户是否存在。您也可以同时删除usernameDB
和passwordDB
从您的admin_model
.
控制器功能:
public function validate_form()
{
$data = array('success' => false, 'messages' => array());
$this->form_validation->set_rules('username', 'Username', 'required|trim|xss_clean');
$this->form_validation->set_rules('password', 'Password', 'required|trim|xss_clean|is_user_exists');
$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 is_user_exists()
{
if ($this->admin_model->login($this->input->post('username', TRUE), $this->input->post('password', TRUE))) {
return true;
} else {
$this->form_validation->set_message('is_user_exists', 'Login failed. Username or password is incorrect');
return false;
}
}
模型功能:
public function login($username, $password)
{
$this->db->where('username', $username);
$this->db->where('password', md5($password));
$query = $this->db->get('adminuser');
if ($query->num_rows() > 0) {
return true;
} else {
return false;
}
}
注意:md5
用于加密密码不好。有关更多详细信息,请参阅 Alex 的评论。
推荐阅读
- jmeter - 在 jmeter 中禁用打开最近选项
- javascript - 我可以在 .save 中更改集合名称吗?
- c# - 需要在两个不同的类中添加相同的属性
- angular - 以角度 6 打印嵌套的 ng-template
- javascript - 如何在不使用 for 循环的对象数组中搜索 ID?
- angularjs - 如何在 AngularJS 中使用嵌套循环
- excel - 使用 Union 将多个范围复制到 Word 文档,范围之间没有空白单元格
- blueprism - BluePrism.BPCoreLib.InvalidValueException:未定义服务器配置“默认”
- powerapps - Power app 数据表迭代。
- ios - 如何使用 RxSwift 强制点击 UIButton?