Ошибка проверки Codeigniter 3 вместе с функцией обратного вызова не отображается - PullRequest
0 голосов
/ 30 апреля 2019

Я хочу проверить форму входа с помощью 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);
                    });
                }
            }
        });
    });

Мне нужен правильный порядок ошибок проверки, например, если имя пользователя или пароль пустые, то сначала должны отображаться соответствующие ошибки, такие как имя пользователя или пароль, а затем должны отображаться неправильные или правильные ошибки имени пользователя или пароля. enter image description here

1 Ответ

0 голосов
/ 01 мая 2019

Вы можете попробовать ниже. Вы можете использовать одну функцию обратного вызова, чтобы проверить, существует ли пользователь или нет.

Сначала удалите функции обратного вызова 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 для шифрования пароля не годится. Смотрите комментарий Алекса для более подробной информации.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...