>  기사  >  백엔드 개발  >  PHP는 세션 저장 시간을 설정합니다

PHP는 세션 저장 시간을 설정합니다

王林
王林원래의
2023-05-22 21:55:06890검색

웹사이트 개발에서 세션은 사용자가 웹사이트를 탐색하는 동안 데이터 일관성을 유지하기 위해 웹사이트에서 사용자의 로그인 정보, 장바구니 데이터 및 기타 유사한 정보를 저장하는 데 도움이 되는 매우 중요한 메커니즘입니다. 일반적으로 사용자가 브라우저를 닫으면 세션이 삭제되므로 세션 저장 시간은 매우 짧습니다. 다만, 사용자 정보를 장기간 보관해야 하는 경우에는 세션 저장 시간을 설정해야 합니다. 이번 글에서는 PHP의 세션 저장 시간을 설정하는 방법을 소개하겠습니다.

  1. 세션 저장 시간

세션은 쿠키에 따라 달라지므로 쿠키 만료 시간을 설정하여 세션 저장 시간을 간접적으로 제어할 수 있습니다. 페이지가 세션을 쿠키에 저장하면 쿠키는 특정 기간 동안 사용자 컴퓨터에 저장되었다가 만료 후 브라우저에 의해 삭제됩니다. 이런 방식으로 해당 쿠키를 찾을 수 없기 때문에 세션이 삭제됩니다.

기본적으로 쿠키의 만료 시간은 브라우저 세션 동안입니다. 즉, 브라우저가 닫히지 않는 한 쿠키는 항상 존재합니다. 그러나 쿠키의 만료 시간을 설정하면 쿠키 저장 시간과 세션 저장 시간을 제어할 수 있습니다. 예는 다음과 같습니다.

// 设置过期时间为30天
$expire_time = time() + 60 * 60 * 24 * 30;
setcookie('session_id', session_id(), $expire_time);

이 경우에는 브라우저를 닫은 후에도 세션에 계속 액세스할 수 있도록 setcookie 함수를 사용하여 session_id 쿠키를 설정합니다. $expire_time 변수는 초 단위의 현재 타임스탬프에 30일의 초 수를 더한 값으로 설정됩니다. 즉, 이 쿠키는 30일 후에 만료됩니다.

  1. session.gc_maxlifetime

php.ini 파일에서 session.gc_maxlifetime 옵션을 수정하여 세션의 최대 수명을 설정할 수도 있습니다. 이 옵션은 최대 세션 수명을 초 단위로 지정합니다. 세션이 만료되면, 즉 이 시간 이후에는 PHP의 가비지 수집 메커니즘에 의해 자동으로 파기됩니다. 기본적으로 이 옵션의 값은 1440초(즉, 24분)입니다. php.ini 파일에서 이 값을 다음과 같이 수정할 수 있습니다:

session.gc_maxlifetime = 1800

이렇게 하면 모든 세션이 30분 동안 저장됩니다. 시간이 더 오래 걸리면 이 값을 더 큰 값으로 설정할 수 있습니다.

최대 세션 수명을 너무 길게 설정하면 너무 많은 서버 리소스를 차지하여 서버 부하가 너무 높아질 수 있다는 점에 유의하세요.

  1. session_set_cookie_params

setcookie 함수를 사용하여 쿠키 만료 시간을 설정하고 php.ini 파일에서 session.gc_maxlifetime 옵션을 수정하여 세션의 최대 수명을 설정하는 것 외에도 session_set_cookie_params를 사용할 수도 있습니다. 쿠키를 설정하기 위해 PHP에서 제공하는 함수입니다. 일부 매개변수는 세션 저장 시간을 간접적으로 제어합니다. 이 함수는 4개의 매개변수를 허용합니다:

$lifetime: 쿠키 수명(초)
  • $path: 쿠키 경로;
  • $domain: 쿠키 도메인 이름; HTTPS 프로토콜을 통해 전송됩니다.
  • session_start 함수를 사용하여 세션을 시작하면 이러한 매개변수가 적용되어 세션 저장 시간을 제어합니다. 다음은 session_set_cookie_params 함수를 사용하여 쿠키 수명을 설정하는 샘플 코드입니다.
  • session_set_cookie_params($lifetime, $path, $domain, $secure);
  • 이 예에서는 쿠키 수명을 1시간으로 설정하고 쿠키 경로를 전체 도메인 이름으로 설정합니다. 이 기간 동안 클라이언트에 저장됩니다. 이 접근 방식은 쿠키 만료 시간을 직접 설정하는 것보다 더 유연합니다. 세션 저장 시간을 세밀하게 제어하기 위해 언제든지 쿠키 경로와 도메인 이름을 수정할 수도 있기 때문입니다.

요약

    세션은 웹 개발에서 매우 중요한 메커니즘으로, 사용자 인증, 장바구니 등 웹사이트에 유용한 많은 기능을 제공할 수 있습니다. 장기간 동안 사용자 정보를 저장해야 하는 경우 세션 저장 시간을 제어해야 합니다. PHP에서는 쿠키 만료 시간을 설정하거나, php.ini 파일에서 session.gc_maxlifetime 옵션을 수정하거나, session_set_cookie_params 함수를 사용하여 이를 달성할 수 있습니다. 세션 저장 시간이 너무 길면 서버의 부하가 증가하여 서버 문제가 발생할 수 있으므로 실제 필요에 따라 세션 저장 시간을 합리적으로 설정해야 합니다.

위 내용은 PHP는 세션 저장 시간을 설정합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.