我是代码点火器的新手,想知道如何在数据库中使用会话表的会话。 我用这个sctructure创建了会话表。
CREATE TABLE `sys_sessions` (
`session_id` VARCHAR(40) NOT NULL DEFAULT '0' COLLATE 'utf8_unicode_ci',
`ip_address` VARCHAR(16) NOT NULL DEFAULT '0' COLLATE 'utf8_unicode_ci',
`user_agent` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`last_activity` INT(10) UNSIGNED NOT NULL DEFAULT '0',
`user_data` TEXT NOT NULL COLLATE 'utf8_unicode_ci',
PRIMARY KEY (`session_id`)
)
COLLATE='utf8_unicode_ci'
ENGINE=InnoDB;
并使用两个控制器来测试使用的会话。首先我运行set_session_test()控制器。
public function set_session_test()
{
$this->load->library('session');
$this->session->set_userdata('username', 'Jhon');
$this->session->set_userdata('email', 'jhon@gmail.com');
echo "<pre>"; print_r($this->session->all_userdata()); echo "</pre>";
}
结果
Array
(
[session_id] => dd7e0e2266da6481ef45faaa7e3c808b
[ip_address] => 127.0.0.1
[user_agent] => Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36
[last_activity] => 1387619782
[user_data] =>
[username] => Jhon
[email] => jhon@gmail.com
)
然后我运行get_session_test()来检查它的会话值是否仍然存在。
public function get_session_test()
{
$this->load->library('session');
$this->session->userdata('username');
$this->session->userdata('email');
echo "<pre>"; print_r($this->session->all_userdata()); echo "</pre>";
}
结果是
Array
(
[session_id] => 1b10e3671728804a63266bb9295b7e5d
[ip_address] => 127.0.0.1
[user_agent] => Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36
[last_activity] => 1387619831
[user_data] =>
)
不幸的是,我没有找到我存储的任何用户名和电子邮件会话。我检查表sys_session,它创建两行session_id。问题是
提前......
答案 0 :(得分:3)
已经在codigntier中提供了存储会话的条款 please check the link
您必须首先为此目的创建数据库表
CREATE TABLE IF NOT EXISTS `ci_sessions` (
session_id varchar(40) DEFAULT '0' NOT NULL,
ip_address varchar(45) DEFAULT '0' NOT NULL,
user_agent varchar(120) NOT NULL,
last_activity int(10) unsigned DEFAULT 0 NOT NULL,
user_data text NOT NULL,
PRIMARY KEY (session_id),
KEY `last_activity_idx` (`last_activity`)
);
创建数据库表后,可以在config.php文件中启用数据库选项,如下所示:
$config['sess_use_database'] = TRUE;
答案 1 :(得分:0)
当您的数据库中的user_agent
字段太短时会发生此行为:
`user_agent` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci'
实际上,当你计算当前user_agent中的字符时,你有超过50个字符,因此CI将不会在数据库中找到任何具有此user_agent的会话,因为它之前存储的截断为50个字符。
尝试将此字段设置得更大,以解决您的问题:
`user_agent` VARCHAR(250) NOT NULL COLLATE 'utf8_unicode_ci'