> 백엔드 개발 > PHP 튜토리얼 > 30분 동안 활동이 없으면 PHP 세션을 안정적으로 만료하는 방법은 무엇입니까?

30분 동안 활동이 없으면 PHP 세션을 안정적으로 만료하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-24 22:56:15
원래의
449명이 탐색했습니다.

How to Reliably Expire a PHP Session After 30 Minutes of Inactivity?

30분 후 PHP 세션을 효과적으로 만료하는 방법

PHP는 세션 만료를 위해 session.gc_maxlifetime 및 session.cookie_lifetime과 같은 옵션을 제공하지만, 그것들은 완전히 신뢰할 수는 없습니다. 다음은 자체 세션 시간 초과 메커니즘을 구현하기 위한 포괄적인 접근 방식입니다.

PHP 내장 옵션 관련 문제:

  • session.gc_maxlifetime : 세션 데이터가 "가비지"로 간주되어 세션 시작 중에 정리되는 시기를 지정합니다. 그러나 가비지 수집기는 기본 확률이 1%에 불과하여 산발적으로 실행되어 잠재적으로 세션이 조기 종료될 수 있습니다.
  • session.cookie_lifetime: 이 옵션은 전송된 세션 쿠키의 수명을 결정합니다. 브라우저에. 그러나 세션 자체를 무효화하지는 않으며 이는 서버의 책임입니다.

사용자 정의 세션 시간 초과 구현:

특정 기간 동안 활동이 없으면 세션을 종료하는 것은 자체 시간 초과 메커니즘을 구현하는 것입니다. 여기에는 마지막 활동(요청)의 타임스탬프를 유지하고 각 요청마다 업데이트하는 작업이 포함됩니다. 마지막 활동이 30분 이상 지난 경우 세션 설정을 해제하고 삭제할 수 있습니다.

if (isset($_SESSION['LAST_ACTIVITY']) && (time() - $_SESSION['LAST_ACTIVITY'] > 1800)) {
    // last request was more than 30 minutes 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
로그인 후 복사

세션 데이터를 지속적으로 업데이트하면 세션 파일의 수정 날짜가 가비지 수집기에 의해 조기에 제거되는 것을 방지할 수 있습니다.

추가 보안 조치:

세션 등 공격 방지 수정하려면 $_SESSION['CREATED'] 타임스탬프를 업데이트하여 주기적으로 세션 ID를 다시 생성할 수 있습니다:

if (!isset($_SESSION['CREATED'])) {
    $_SESSION['CREATED'] = time();
} else if (time() - $_SESSION['CREATED'] > 1800) {
    // session started more than 30 minutes ago
    session_regenerate_id(true); // change session ID for the current session and invalidate old session ID
    $_SESSION['CREATED'] = time(); // update creation time
}
로그인 후 복사

참고:

  • 세션을 확인하세요. gc_maxlifetime은 최소한 사용자 정의 만료 핸들러의 수명(여기서는 1800)과 동일한 값으로 설정됩니다. 예).
  • 시작 이후가 아닌 활동 30분 후에 세션을 만료하려면 만료 시간 time() 60 * 30과 함께 setcookie를 사용하여 세션 쿠키를 활성 상태로 유지하세요.

위 내용은 30분 동안 활동이 없으면 PHP 세션을 안정적으로 만료하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿