【发布时间】:2013-10-31 04:52:41
【问题描述】:
我目前正在开发一个网络应用程序,用户登录会话被创建并登录到数据库。
正在发生的情况是,用户将被随机注销,而他们自己没有选择。背景故事是,这通常发生在共享帐户的用户身上(不是最好的事情,而是应用程序的性质,这意味着它需要被允许)。
这可能是随机注销的原因吗?还是 CI 中的一些更深层次的东西和在数据库中存储会话?我还读到同时执行大量 AJAX 请求会导致 SESSION ID 更改,然后可能会覆盖数据库记录并将用户注销。这又是一种可能吗?我认为这个不太好,因为我已经写了一个补丁来阻止这种情况发生。
会话配置:
$config['sess_cookie_name'] = 'app';
$config['sess_expiration'] = 0;
$config['sess_expire_on_close'] = FALSE;
$config['sess_encrypt_cookie'] = TRUE;
$config['sess_use_database'] = TRUE;
$config['sess_table_name'] = 'ci_sessions';
$config['sess_match_ip'] = FALSE;
$config['sess_match_useragent'] = FALSE;
$config['sess_time_to_update'] = 300;
$config['sess_use_multisessions'] = TRUE;
$config['sess_multisession_expiration'] = 10;
【问题讨论】:
-
你为什么不分享你的一些代码?最好分享您的代码以获得对您的问题的最大响应
-
你想看什么?创建 SESSION 的登录代码?
-
如果您打开隐身会话并尝试使用同一帐户登录会发生什么?
-
如果你可以分享隐身会话的处理......
-
检查配置文件中的
session_expiration..确保其值为0。共享配置文件中的会话配置变量
标签: php codeigniter session