0

我正在使用 Codeigniter 和 Jquery 构建 Ajax 登录...我有一个小问题,即返回“无效登录”消息及其困扰我。

在登录页面上,我有:

$(document).keypress(function (e) {
    if (e.which == 13) {
        var login = $("#login").val();
        var pass = $("#pass").val();

        $('#login-block').removeBlockMessages().blockMessage('Please wait, cheking login...', {
            type: 'loading'
        });
        $.post("<?php echo base_url(); ?>index.php/login/validate_credentials/", {
            username: login,
            password: pass
        }, function (data) {
            if (data.error) {
                $('#login-block').removeBlockMessages().blockMessage(data.message, {
                    type: 'error'
                });
            } else {
                document.location.href = data.redirect;
            }
        }, "json");
    }
});

validate()函数只是查询数据库以查找用户名和密码匹配,如果 num_rows = 1 则返回用户数据。

尝试登录时,所有这些都可以正常工作,但是当我输入不存在的用户名时,我不会收到“登录错误”错误...

如果我使用真实的用户名和错误的密码,我会收到错误消息。

如果用户名和密码正确,则登录正常。

我只是不明白为什么当用户名不存在时它不会显示和错误?

编辑

这是模型中的 Validate() 函数。

function validate() {

    // CHECK LOGIN DETAILS
    $this->db-> select('first_name,last_name,usertype,id,products,mac');
    $this->db-> where('username', $this->input->post('username'));
    $this->db-> where('password', md5($this->input->post('password')));
    $query = $this->db->get('membership');

    if ($query->num_rows() > 0) {
        $data = array('usertype' => $row->usertype, 'userid' => $row->id, 'first_name' => $row->first_name, 'last_name' => $row->last_name, 'products' => $row->products, 'mac' = > $row->mac);
        return $data;
    }
}
4

2 回答 2

0
if(data.error){
    $('#login-block').html('<p>'+data.message+'</p>);
} else {
    document.location.href = data.redirect;
}

试试看。

if($query->num_rows()==1)
{
$data2 = array(
    'error' => false,
    'redirect' => base_url().'index.php/site/home/'
    );

好的,我明白了,怎么样?顺便说一下,在登录时,您应该始终检查 num_rows = 1,永远不应该超过一个。

于 2012-10-08T11:56:38.090 回答
0

$.getJSON('<?php echo base_url(); ?>index.php/login/validate_credentials/',{username: login, password: pass}, function(data) {
if(data.error){
$('#login-block').removeBlockMessages().blockMessage(data.message, {type: 'error'});   
} else {
document.location.href = data.redirect;
}
});

我需要使用 getJSON 而不是 post。我必须更新模型函数以使用 get 而不是 post 变量。它现在像我希望的那样工作。

于 2012-10-08T14:34:53.673 回答