>  기사  >  백엔드 개발  >  PHP로 플레이하는 방법과 SESSION의 생존 시간을 수정하는 방법을 가르쳐주세요.

PHP로 플레이하는 방법과 SESSION의 생존 시간을 수정하는 방법을 가르쳐주세요.

慕斯
慕斯앞으로
2021-06-29 14:04:493729검색

우리는 PHP에 대해 많은 것을 배웠습니다. PHP에서 SESSION의 생존 시간을 수정하는 방법을 완전히 익혔는지 궁금합니다. 그렇지 않다면 이 기사를 따라 계속 학습하세요

요구 사항 배경:

사용자는 로그인한 후 브라우저가 로그인 상태를 기억할 수 있도록 도와주므로 로그인할 때마다 로그인할 필요가 없기를 바랍니다.

세션 만료 시간:

세션 생성 시간을 설정하지 않으면 구성 파일의 기본 생존 시간은 1440초입니다.

즉, 세션 생존 시간이 24분일 수도 있습니다. 이 질문이 있습니다:

로그인 후 24분이 지나도 왜 로그아웃하지 않았나요?

실제로 사용자가 종료하지 않은 이유는 PHP의 재활용 메커니즘 때문입니다.

구성 파일 php.ini에서 위의 두 가지 구성 항목을 찾을 수 있습니다. 위의 설명은 기본적으로 동일합니다. 즉, 대략 다음과 같습니다.

각 세션 초기화 중에 발생하는 "재활용 메커니즘"은 확률 이벤트이며 이 확률은

gc_probability를 gc_pisor로 나눈 공식에서 파생됩니다. gc_probability 값이 1이고 gc_pisor 값이 100인 경우 "재활용 메커니즘"이 트리거될 확률은 1%입니다.

이는 100개의 PHP 요청이 있을 수 있으며 "재활용 메커니즘"을 트리거할 가능성은 단 한 번만 있을 수 있음을 의미합니다. 따라서 세션이 만료되었지만 "재활용 메커니즘"이 트리거되지 않았고 세션 파일이 삭제되지 않은 경우 세션은 여전히 ​​유효합니다.

"재활용 메커니즘"을 매우 정확하게 실행하고 세션이 만료된 후 즉시 세션을 삭제해야 하는 경우 위의 값을 모두 1로 설정하세요.

하지만 이는 PHP 성능에 큰 영향을 미칩니다.

쿠키의 SessionID 생존 시간:

일반적으로 sessionID 만료 시간을 별도로 설정하지 않으면 브라우저는 쿠키에서 해당 sessionid를 삭제합니다.

브라우저를 닫지 않았고, 세션 시간이 만료되어 무효화되었습니다. 그러나 PHP의 재활용 메커니즘으로 인해(다음 문서: PHP 세션 세부 설명 참조) 즉시 만료되지 않을 수 있습니다.

예:

<?php

session_start();

$_SESSION["username"] = "peter";

echo "登记的用户名为:".$_SESSION["username"];

?>

이 코드를 실행하면 Chrome 브라우저의 애플리케이션에서 방금 방문한 웹사이트의 세션 ID 만료 시간을 확인합니다


1969-12-31, 이는 캐시가 없음을 의미합니다. 설정한 시간은 브라우저를 닫으면 삭제됩니다.

"설정"->"고급"->"콘텐츠 설정"->"쿠키"->"모든 쿠키 및 사이트 보기에서 보고 싶은 웹사이트를 선택할 수도 있습니다. 데이터" 세션 관련 정보를 참조하세요.

위 코드를 다음과 같이 수정했습니다.

<?php

$lifeTime = 24 * 3600;

session_set_cookie_params($lifeTime);

session_start();

$_SESSION["username"] = "peter";

echo "登记的用户名为:".$_SESSION["username"];
?>

이제 쿠키에 설정한 세션의 만료 시간이 수정된 것을 확인할 수 있습니다


세션 설정 생존 시간

1. 가장 효과적인 방법은 php.ini

#session的超时时间

session.gc_maxlifetime = 1440

2를 수정하는 것입니다. php

<?php
$Lifetime = 3600;

$DirectoryPath = "./tmp";

is_dir($DirectoryPath) or mkdir($DirectoryPath, 0777);

//是否开启基于url传递sessionid,这里是不开启,发现开启也要关闭掉

if (ini_get("session.use_trans_sid") == true) {

ini_set("url_rewriter.tags", "");

ini_set("session.use_trans_sid", false);

}

ini_set("session.gc_maxlifetime", $Lifetime);//设置session生存时间

ini_set("session.gc_pisor", "1");

ini_set("session.gc_probability", "1");

ini_set("session.cookie_lifetime", "0");//sessionID在cookie中的生存时间

ini_set("session.save_path", $DirectoryPath);//session文件存储的路径

session_start();
?>

를 통해 이 값을 수정하세요. 참고: 웹 사이트에서 session_save_path를 사용자 정의한 경우 session.gc_probability의 값을 설정해야 합니다. 그렇지 않으면 세션에 의해 생성된 sessionID 파일이 삭제되지 않습니다.


3. Disguise에서 세션 시간을 늘리려면 증가하는 쿠키 시간을 사용하세요

<?php
/**

* 下面只是设置了保存sessionid的那个时间,这样的结果是关闭浏览器后session仍可以用

* 实际并没有改变session的生存时间,如果session已经过期,这也就没有意义了

*/

//只会在用户第一次访问的时候设置保存sessionid的那个cookie的过期时间

$lifetime=600;

session_set_cookie_params($lifetime);#注意到放到start的前面

session_start();



//每次都设置保存sessionid的那个cookie的过期时间

$lifetime=600;

session_start();

setcookie(session_name(),session_id(),time()+$lifetime);

?>

//위와 동일하며 매번 설정됩니다

참고: 개인적으로는 두 번째 방법을 설정하거나 사용하는 것이 좋습니다. 첫 번째 방법 이러한 사고는 세 번째 방법과 결합되어 문제를 근본적으로 해결할 수 있다.

<?php

$lifetime=86400;

session_set_cookie_params($lifetime);

session_start();

session_regenerate_id(true);

?>

推荐学习:《PHP视频教程

 

 

위 내용은 PHP로 플레이하는 방법과 SESSION의 생존 시간을 수정하는 방법을 가르쳐주세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제