我知道我们可以使用php ini设置。通过设置会话cookie的生命周期增加。但如果没有php ini设置,如何在codeigniter中执行此操作。
我的配置文件
$config['sess_driver'] = 'database';
$config['sess_use_database'] = TRUE;
$config['sess_cookie_name'] = 'ci_session';
$config['sess_expiration'] = 60*60*24*180;
$config['sess_save_path'] = 'ci_sessions';
$config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 0;
$config['sess_regenerate_destroy'] = FALSE;
答案 0 :(得分:1)
第一步是在数据库中为该用户ID创建一个令牌字段,当我们第一次为用户设置cookie令牌创建会话数据库中的dupdate时。然后每次登录时从浏览器检查用户cookie并检查匹配的数据库令牌并为用户启动会话。 请检查我的以下代码
$values = array(
'user_id' => $row->id,
'logged_in' => TRUE,
'role' => $row->role_id,
'email' =>$row->email
);
$this->session->set_userdata($values);
$cookie = array(
'name' => 'token',
'value' => generateRandomString() ,
'expire' => '1209600',
'domain' => domain() ,
'path' => '/'
);
set_cookie($cookie);
$update = array(
'token' => $cookie['value'],
);
$this->db->where('id', $row->id);
$this->db->update('user', $update);
if ($CI->session->userdata('logged_in')==1 && $CI->session->userdata('user_id')) {
$query = $CI->db->query("select * from user where token= '".$token."' and role_id=2");
$result = $query->row();
if($result->token==$token){
$values = array(
'user_id' => $result->id,
'logged_in' => TRUE,
'role' => $result->role_id,
'email' =>$result->email
);
$CI->session->set_userdata($values);
答案 1 :(得分:0)
您将按IP启用会话。
$config['sess_match_ip'] = TRUE;
因此,如果您关闭浏览器并再次打开它,则codeigniter CI会话将检测到相同的IP并重新建立会话。 仅当您打开网站时才能使用同一台PC打开并且IP同时没有更改。