Для работы с сессией, в Limb есть специальный объект session, который можно получить через тулкит:
$session = lmbToolkit :: instance()->getSession(); $session->set('my_var', $value); // Поставить значение в сессию $var = $session->get('my_var'); // Получить значение из сессии $session->foo = $value; // Поставить значение в сессию $bar = $session->foo; // Получить значение из сессии
Классы, реализующие работу с сессией, находятся в пакете SESSION.
Преимущества использования пакета SESSION:
Метод getSession() реализован в классе lmbWebAppTools.
При работе с сессией используются 2 понятия:
Хранище сессионных данных необходимо инициализировать. Инициализация производится в класса lmbSessionStartupFilter, который обычно входит в цепочку фильтров приложения, выполненного на базе Limb3.
lmbSessionStartupFilter опирается на константу LIMB_SESSION_USE_DB_DRIVER для определения, какой тип хранилица сессионных данных использовать.
При использовании класса lmbSessionDbStorage в качестве хранилища (вернее сказать, драйвера хранилища) сессионных данных, вы можете также использовать константу LIMB_SESSION_DB_MAX_LIFE_TIME, которая указывает время жизни сессии между двумя обращениями. Если эта константа не определена - то будет использоваться значение указанное в системных настройках для PHP.
Для хранения сессионных данных в базе данных используется таблице sys_session со следующей структурой:
CREATE TABLE `sys_session` ( `session_id` VARCHAR(50) NOT NULL DEFAULT '', `session_data` BLOB NOT NULL, `last_activity_time` BIGINT(11) UNSIGNED DEFAULT NULL, PRIMARY KEY (`session_id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
Обсуждение