Php 代码点火器3和会话

Php 代码点火器3和会话,php,codeigniter,session,codeigniter-3,Php,Codeigniter,Session,Codeigniter 3,在2.x版本的CI中,我的会话运行良好。我曾经使用默认的CI会话选项(我相信是浏览器)保存它们,但现在我决定使用数据库。我已经在配置文件中设置了表和其他所有内容。问题是我从来没有犯过任何错误。会话和加密库位于自动加载配置文件中。在我的模型中,我使用以下代码将数据放入会话: $this->session->set_userdata(array( 'email' => $email, 'is_logged_in' => 1) ); 但当我尝试使用: var_dum

在2.x版本的CI中,我的会话运行良好。我曾经使用默认的CI会话选项(我相信是浏览器)保存它们,但现在我决定使用数据库。我已经在配置文件中设置了表和其他所有内容。问题是我从来没有犯过任何错误。会话和加密库位于自动加载配置文件中。在我的模型中,我使用以下代码将数据放入会话:

$this->session->set_userdata(array(
  'email' => $email,
  'is_logged_in' => 1)
); 
但当我尝试使用:

var_dump($this->session->userdata());
我得到以下输出:

array(1) { ["__ci_last_regenerate"]=> int(1448664996) }
未向会话添加任何内容,未显示任何错误。有人能帮忙吗

编辑:

config.php

$config['sess_driver'] = 'database';
$config['sess_cookie_name'] = 'mydomain';
$config['sess_expiration'] = 7200;
$config['sess_save_path'] = 'ci_sessions';
$config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 300;
$config['sess_regenerate_destroy'] = FALSE;
autoload.php

$autoload['libraries'] = array('database', 'email', 'encryption', 'session');
我已经按照文档显示的所有说明进行了操作

编辑2:

控制器:

public function login_into_site()
    {
        if($this->input->post('viaAjax') == 1)
        {
            $this->form_validation->set_rules('email', 'Email', 'required|trim|valid_email|callback_validate_credentials');
            $this->form_validation->set_rules('password', 'Password', 'required|md5|trim');
            $user_url = base64_decode($this->input->post('rand'));

            if ($this->form_validation->run())
            {
                $sulo = array();
                $sulo['res'] = '1';
                $sulo['address'] = $user_url;
                echo json_encode($sulo);
            }
            else
            {
                $formError = array();
                $formError['email'] = form_error('email');
                $formError['password'] = form_error('password');
                echo json_encode($formError);
            }
        }
        else
        {
            echo json_encode("fail");
        }
    }

    public function validate_credentials()
    {
        $this->load->model('user/model_user_auth');
        $this->model_user_auth->can_log_in($message);
        if($message == 1)
        {
            return true;
        }
        else if($message == 2)
        {
            $this->form_validation->set_message('validate_credentials','not activated');
            return false;
        }
        else
        {
            $this->form_validation->set_message('validate_credentials','bad username or password');
            return false;
        }
    }
型号:

public function can_log_in(&$message)
    {
        $email = $this->input->post('email');
        $this->db->where('email',$email);
        $this->db->where('password',md5($this->input->post('password')));
        $query = $this->db->get('users');
        $message = '';
        if($query->num_rows() == 1)
        {
            $this->session->set_userdata(array(
                'email' => $email,
                'is_logged_in' => 1)
            );

            foreach ($query->result() as $row)
            {
                $activated = $row->activate;
                $membership = $row->membership;
            }
            if($activated == NULL && $membership == 'a')
            {
                $message = 1; //success
            }
            else if($activated != NULL && $membership == 'a')
            {
                $message = 2; //not activated
            }
            else
            {
                $message = 3; // user exist but info wrong
            }
        }
        else
        {
            $message = 0; // user does not exist
        }
    }

模型生成
$message=1,因为我在控制器回调函数和控制器函数中得到返回为“TRUE”的结果,该函数记录用户在继续时没有任何错误

已解决。问题是我的cookie覆盖了数据库会话。在配置文件中,如果将数据库用于会话,此行不能有值“

为了让会话使用数据库工作,该值必须为空:

$config['sess_cookie_name'] = '';

如果不为空,CI将默认为会话的Cookie。这并不意味着您不能使用Cookie。您只需通过helper加载它们,它们就可以正常工作。

您创建的表,是用于CI2还是CI3?@Tpojka用于CI3。我是从您为什么提到CI2得到的?@Tpojka“我在2.x版本的CI中会话工作正常。”,用于在2中工作。3中的否不适用work@Tpojka如果可能的话,我已经添加了配置信息。我感到困惑的原因是,代码看起来正常,并没有错误,但它并没有保存会话信息。其余的代码执行得很好。即使我把
$\u SESSION['email']=$email
放进去也不起作用,但如果我把
SESSION\u start()放进去我收到一个会话已启动的错误。请说明此信息的来源好吗?我正在使用redis会话,并将会话ID存储在一个带有名称的cookie中,一切都很好。我很想了解更多关于你上面提到的观点。
$config['sess_cookie_name'] = '';