PHP сессии

FAQ - прежде, чем спросить.
Здесь Вы можете найти ответы на часто задаваемые вопросы.

FAQ - перш, ніж запитати.
Тут Ви можете знайти відповіді на найбільш поширені запитання.
Ответить
likypedia
Сообщения: 1
Зарегистрирован: Пт авг 28, 2015 7:47 pm
Пол: Не указан

PHP сессии

Сообщение likypedia »

Если можно, то как настроить, чтобы сессии PHP удалялись в конкретное время (например в 02.00) или жили, например, на протежении 8 часов ??
TarasUA
Сообщения: 14
Зарегистрирован: Пт апр 10, 2015 4:48 pm
Пол: Не указан

Re: PHP сессии

Сообщение TarasUA »

Рекоммендуем установить время таймаута сессий, используя время последнего действия, т.е. запроса, и обновляя его с каждым запросом:

Код: Выделить всё

if (isset($_SESSION['LAST_ACTIVITY']) && (time() - $_SESSION['LAST_ACTIVITY'] > 28800)) {
    // last request was more than 8 hours ago
    session_unset();     // unset $_SESSION variable for the run-time 
    session_destroy();   // destroy session data in storage
}
$_SESSION['LAST_ACTIVITY'] = time(); // update last activity time stamp
Обновление данных сессии с каждым запросом меняет дату изменения файла сессий, что предотвращает преждевременное удаление сессии.

Можно также применять дополнительное время для переодического перегенерирования ID сессии с целью предотвращения атак:

Код: Выделить всё

if (!isset($_SESSION['CREATED'])) {
    $_SESSION['CREATED'] = time();
} else if (time() - $_SESSION['CREATED'] > 28800) {
    // session started more than 8 hours ago
    session_regenerate_id(true);    // change session ID for the current session and invalidate old session ID
    $_SESSION['CREATED'] = time();  // update creation time
}
Ответить

Вернуться в «FAQ»