PHP 웹사이트를 작성할 때 개발자는 페이지 간 정보 전송 및 사용자 인증과 같은 기능을 구현하기 위해 세션에 사용자 데이터를 저장하는 경우가 많습니다. 기본적으로 PHP 세션은 세션이 종료되면 자동으로 지워지거나 브라우저가 닫힐 때 만료됩니다. 그러나 개발자는 특정 기간 동안 세션을 유효하게 유지하기 위해 세션 만료 시간을 보다 정확하게 제어해야 하는 경우가 있습니다. 이 기사에서는 PHP에서 세션 만료 시간을 설정하는 방법을 소개합니다.
시작하기 전에 다음 두 가지 개념을 이해해야 합니다.
세션 ID: 서버와 세션을 설정할 때 각 사용자에게 고유한 세션 ID가 할당됩니다. 이 ID는 사용자의 세션을 식별하는 데 사용됩니다. 세션.
세션 변수: 세션 변수는 세션 중에 서버 측에 저장되는 변수를 의미하며 사용자 데이터를 저장하는 데 사용됩니다.
2.1. php.ini 파일 수정
PHP의 세션 만료 시간은 session.gc_maxlifetime 매개변수를 사용하여 php.ini 구성 파일에서 초 단위로 설정할 수 있습니다. 기본적으로 해당 값은 1440초, 즉 24분입니다. 아래 단계에 따라 수정할 수 있습니다.
이 매개변수를 수정하면 모든 PHP 스크립트의 세션 만료 시간에 영향을 미칩니다.
2.2. 코드에 설정
특정 페이지의 세션 만료 시간만 수정해야 하거나 필요에 따라 코드에서 세션 만료 시간을 동적으로 설정해야 하는 경우 다음 코드를 사용할 수 있습니다.
session_start (); // 세션 시작
$expireTime = 60*30; // 만료 시간은 30분입니다
$_SESSION['timeout'] = time() + $expireTime; 세션 변수
?> ;
코드에서 $_SESSION['timeout']을 사용하여 만료 시간과 관련된 세션 변수를 지정합니다. 현재 타임스탬프(time()) 값과 만료 시간($expireTime)을 저장합니다. 페이지를 방문할 때마다 이 변수가 만료되었는지 확인할 수 있습니다. 만료된 경우 session_destroy() 함수를 호출하여 세션을 삭제합니다.
2.2.1. 세션 수명 주기 매개변수 수정
session_set_cookie_params() 함수를 사용하여 코드에서 세션 만료 시간을 설정할 수도 있습니다. 이 함수는 여러 매개변수를 허용할 수 있으며, 그 중 가장 중요한 매개변수는 세션 만료 시간을 결정하는 세션 수명 주기 매개변수입니다.
다음은 예시입니다.
session_start();
$expireTime = 60*30; // 만료 시간은 30분입니다.
session_set_cookie_params($expireTime);
?>
이 코드 세션 만료 시간은 30분으로 설정됩니다.
php.ini 파일을 수정하거나, 코드에서 설정하거나, 세션 수명 주기 매개변수를 통해 설정하는 경우 다음과 같은 참고사항이 있습니다.
Session은 PHP 애플리케이션을 작성할 때 매우 중요한 기능입니다. 세션 만료 시간을 설정하면 사용자 데이터의 보안을 더욱 효과적으로 보호하고 불필요한 서버 리소스 낭비를 방지할 수 있습니다.
위 내용은 PHP에서 세션 만료 시간을 설정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!