>백엔드 개발 >PHP 튜토리얼 >PHP 설정 세션(만료, 무효화, 유효기간)에 대한 자세한 설명_php 스킬

PHP 설정 세션(만료, 무효화, 유효기간)에 대한 자세한 설명_php 스킬

WBOY
WBOY원래의
2016-05-16 20:04:571719검색

PHP에서 세션을 설정하는 방법에는 세션 값을 설정하거나 만료, 만료 및 유효 기간을 직접 설정하는 등 여러 가지 측면이 있습니다. 다음 편집기에서 사용 방법을 소개합니다.

먼저 php.ini에서 세션을 설정하는 방법을 살펴보겠습니다. php.ini를 열고 세션 설정 섹션에서 다음 항목을 찾으세요.

session.save_path = "N;/path" 
session.save_path = "C:/Temp"  #此处以你自己设定的路径为准

이 설정을 사용하면 세션 저장 디렉터리에 대해 다단계 해싱을 수행할 수 있습니다. 여기서 "N"은 설정할 디렉터리 수준을 나타내고 다음 "/path"는 세션 파일이 저장되는 루트 디렉터리 경로를 나타냅니다. 예를 들어 다음 형식으로 설정하면 코드는 다음과 같습니다.

session.save_path = "2;C:/Temp"

위 설정은 PHP 세션 파일을 2단계 디렉터리에 저장한다는 의미입니다. 각 디렉터리 수준은 0-9와 a-z이며 총 36개의 영숫자 이름을 디렉터리 이름으로 사용합니다. 최대 36*36개의 폴더를 저장할 수 있으며, 이는 단일 서버에 충분하다고 생각됩니다. 시스템 아키텍처가 여러 서버와 세션 데이터를 공유하도록 설계된 경우 디렉터리 수준을 3개 이상으로 늘릴 수 있습니다.

세션 만료 시간 설정

PHP의 세션 주제에 이어 PHP에서 세션의 수명 주기는 주로 다음 코드와 같이 session.gc_maxlifetime을 설정하여 설정됩니다.

<&#63;php 
ini_set('session.gc_maxlifetime', 3600); //设置时间 
ini_get('session.gc_maxlifetime');//得到ini中设定值 
&#63;> 

다음은 다른 분들이 패키징한 함수인데, 테스트해보지는 않았습니다. 코드는 다음과 같습니다.

<&#63;php 
function start_session($expire = 0) 
{ 
 if ($expire == 0) { 
 $expire = ini_get('session.gc_maxlifetime'); 
 } else { 
 ini_set('session.gc_maxlifetime', $expire); 
 } 
 if (emptyempty($_COOKIE['PHPSESSID'])) { 
 session_set_cookie_params($expire); 
 session_start(); 
 } else { 
 session_start(); 
 setcookie('PHPSESSID', session_id(), time() + $expire); 
 } 
} 
&#63;> 

사용법:

start_session(600) 추가; //600초 후에 만료됩니다.

세션이 만료되지 않는 방법

php.ini 설정 파일을 열고 다음과 같이 세 줄을 수정합니다.

1. session.use_cookies

이 값을 1로 설정하고 쿠키를 사용하여 세션 ID를 전달합니다

2. session.cookie_lifetime

SessionID가 클라이언트 쿠키에 저장되는 시간을 나타냅니다. 기본값은 0입니다. 이는 브라우저가 닫히자마자 SessionID가 무효화된다는 의미입니다... 이로 인해 PHP 세션을 영구적으로 사용할 수 없습니다. ! 그럼 우리가 생각하기에 크다고 생각되는 숫자로 설정해 보겠습니다. 999999999는 어떻습니까? 괜찮습니다! 그게 다야.

3. session.gc_maxlifetime

서버 측에 세션 데이터가 저장되는 시간입니다. 이 시간을 초과하면 세션 데이터가 자동으로 삭제됩니다! 그럼 99999999로 설정해 보겠습니다.

그렇습니다. 물론 믿을 수 없다면 테스트해 보세요. 세션을 설정하고 10일 반 후에 컴퓨터가 정전되지 않으면 다시 오세요. 또는 충돌이 발생하더라도 여전히 이 세션 ID를 볼 수 있습니다.

물론 서버를 제어할 권한이 없고 php.ini 설정을 수정하는 것이 저만큼 운이 좋지 않을 수도 있습니다. 물론 우리가 직접 해야 하는 방법도 있습니다. 클라이언트를 사용하여 쿠키를 저장하고 sessionID를 가져옵니다. 이를 클라이언트의 쿠키에 저장하고 이 쿠키의 값을 설정한 다음 이 값을 session_id() 함수에 전달합니다.

<&#63;php 
session_start(); // 启动Session 
$_SESSION['count']; // 注册Session变量Count 
isset($PHPSESSID)&#63;session_id($PHPSESSID):$PHPSESSID = session_id(); 
// 如果设置了$PHPSESSID,就将SessionID赋值为$PHPSESSID,否则生成SessionID 
$_SESSION['count']++; // 变量count加1 
setcookie('PHPSESSID', $PHPSESSID, time()+3156000); // 储存SessionID到Cookie中 
echo $count; // 显示Session变量count的值 
&#63;> 

위 내용은 PHP에서 세션을 설정하는 구체적인 방법으로, 세션 값을 설정하거나 만료, 무효화, 유효 기간을 직접 설정하는 방법으로 모든 분들의 학습에 도움이 되기를 바랍니다.

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