웹사이트 개발에서 세션은 사용자가 웹사이트를 탐색하는 동안 데이터 일관성을 유지하기 위해 웹사이트에서 사용자의 로그인 정보, 장바구니 데이터 및 기타 유사한 정보를 저장하는 데 도움이 되는 매우 중요한 메커니즘입니다. 일반적으로 사용자가 브라우저를 닫으면 세션이 삭제되므로 세션 저장 시간은 매우 짧습니다. 다만, 사용자 정보를 장기간 보관해야 하는 경우에는 세션 저장 시간을 설정해야 합니다. 이번 글에서는 PHP의 세션 저장 시간을 설정하는 방법을 소개하겠습니다.
세션은 쿠키에 따라 달라지므로 쿠키 만료 시간을 설정하여 세션 저장 시간을 간접적으로 제어할 수 있습니다. 페이지가 세션을 쿠키에 저장하면 쿠키는 특정 기간 동안 사용자 컴퓨터에 저장되었다가 만료 후 브라우저에 의해 삭제됩니다. 이런 방식으로 해당 쿠키를 찾을 수 없기 때문에 세션이 삭제됩니다.
기본적으로 쿠키의 만료 시간은 브라우저 세션 동안입니다. 즉, 브라우저가 닫히지 않는 한 쿠키는 항상 존재합니다. 그러나 쿠키의 만료 시간을 설정하면 쿠키 저장 시간과 세션 저장 시간을 제어할 수 있습니다. 예는 다음과 같습니다.
// 设置过期时间为30天 $expire_time = time() + 60 * 60 * 24 * 30; setcookie('session_id', session_id(), $expire_time);
이 경우에는 브라우저를 닫은 후에도 세션에 계속 액세스할 수 있도록 setcookie 함수를 사용하여 session_id 쿠키를 설정합니다. $expire_time 변수는 초 단위의 현재 타임스탬프에 30일의 초 수를 더한 값으로 설정됩니다. 즉, 이 쿠키는 30일 후에 만료됩니다.
php.ini 파일에서 session.gc_maxlifetime 옵션을 수정하여 세션의 최대 수명을 설정할 수도 있습니다. 이 옵션은 최대 세션 수명을 초 단위로 지정합니다. 세션이 만료되면, 즉 이 시간 이후에는 PHP의 가비지 수집 메커니즘에 의해 자동으로 파기됩니다. 기본적으로 이 옵션의 값은 1440초(즉, 24분)입니다. php.ini 파일에서 이 값을 다음과 같이 수정할 수 있습니다:
session.gc_maxlifetime = 1800
이렇게 하면 모든 세션이 30분 동안 저장됩니다. 시간이 더 오래 걸리면 이 값을 더 큰 값으로 설정할 수 있습니다.
최대 세션 수명을 너무 길게 설정하면 너무 많은 서버 리소스를 차지하여 서버 부하가 너무 높아질 수 있다는 점에 유의하세요.
setcookie 함수를 사용하여 쿠키 만료 시간을 설정하고 php.ini 파일에서 session.gc_maxlifetime 옵션을 수정하여 세션의 최대 수명을 설정하는 것 외에도 session_set_cookie_params를 사용할 수도 있습니다. 쿠키를 설정하기 위해 PHP에서 제공하는 함수입니다. 일부 매개변수는 세션 저장 시간을 간접적으로 제어합니다. 이 함수는 4개의 매개변수를 허용합니다:
$lifetime: 쿠키 수명(초)session_set_cookie_params($lifetime, $path, $domain, $secure);
위 내용은 PHP는 세션 저장 시간을 설정합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!