Codeigniter会话存储在数据库中,但不起作用

时间:2018-09-23 13:34:44

标签: php codeigniter session

我有两个非常简单的控制器: 一种是用于设置会话:

defined('BASEPATH') OR exit('No direct script access allowed');
class Ses extends CI_Controller {


    public function index()
    {
    $this->session->set_userdata('userId', 'myId');
    print_r($this->session->userdata());


    echo '<a href="'.base_url('ses2').'">Ses2</a>'; 
    }
}

它会打印会话:

Array ( [__ci_last_regenerate] => 1537709001 [userId] => myId ) Ses2

因此,会话已设置并且可以正常工作。但是,当我单击链接“ ses2”时,我有另一个控制器:

if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class Ses2 extends CI_Controller 
    {


    function index()
    {
        print_r($this->session->userdata());
    }   
}

我得到:

Array ( [__ci_last_regenerate] => 1537709217 )

所以我的会话以某种方式消失了:

我正在使用数据库存储会话,这是我的配置:

$config['sess_driver'] = 'database';
$config['sess_cookie_name'] = 'ci_sessions1';
$config['sess_expiration'] = 7200;
$config['sess_save_path'] = 'ci_sessions';//its your table name name
$config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 300;

奇怪的是,当我检查数据库时,bloob数据在那里。

我真的很困惑。

2 个答案:

答案 0 :(得分:0)

实际上,这是Codeigniter 3.1.6和PHP 7.1.7的问题。我刚刚将CI升级到最新版本。

答案 1 :(得分:-1)

设置会话变量的方式应该是这样的。第二个参数应该是值。

$myId='123';
$this->session->set_userdata('userId',$myId);