우리는 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(); ?>
<?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 중국어 웹사이트의 기타 관련 기사를 참조하세요!