>백엔드 개발 >PHP 문제 >PHP 쿠키를 지우는 방법

PHP 쿠키를 지우는 방법

藏色散人
藏色散人원래의
2020-11-24 10:02:322163검색

PHP 쿠키를 삭제하는 방법: 먼저 PHP 샘플 파일을 만든 다음 setcookie를 통해 쿠키를 생성하고 마지막으로 "setcookie('test','',time()-3600);"을 통해 생성된 쿠키를 삭제합니다.

PHP 쿠키를 지우는 방법

권장: "PHP 비디오 튜토리얼"
이 튜토리얼의 운영 환경: Windows 7 시스템, PHP 버전 5.6 이 방법은 모든 브랜드의 컴퓨터에 적합합니다.

PHP는 COOKIE를 지웁니다. PHP는 COOKIE를 삭제할 수 없습니다.

COOKIE 유효 기간, COOKIE 만료 설정

PHP 설명서에는 다음이 언급되어 있습니다.

PHP는 HTTP 쿠키를 투명하게 지원합니다. 쿠키는 사용자를 추적하고 식별하기 위해 원격 브라우저에 데이터를 저장하는 메커니즘입니다. 쿠키는 setcookie() 또는 setrawcookie() 함수를 사용하여 설정할 수 있습니다. 쿠키는 HTTP 헤더의 일부이므로 header() 함수에 대한 제한 사항과 유사하게 다른 정보가 브라우저에 출력되기 전에 setcookie() 함수를 호출해야 합니다.

setcookie():
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )

쿠키를 삭제하려면 만료 날짜가 과거인지 확인하여 브라우저의 삭제 메커니즘을 실행해야 합니다.

쿠키를 삭제하는 방법은 쿠키의 유효기간을 현재 시간 이전으로 설정하는 것인데, 이는 거의 모든 PHP 프로그래머들이 하는 작업입니다.

예:

setcookie('test','true',time()+3600); //创建cookie
setcookie('test','',time()-3600);   //清除建立的cookie

========================================= ==== ======================================

쿠키를 직접 설정하면( "test", ' ');

print_r($_COOKIE);

결과적으로 $_COOKIE['testcookie']뿐만 아니라 전체 $_COOKIE 배열이 비어 있습니다. 그래서 저는 Winsock을 사용하여 패킷을 캡처하고 반환된 http 헤더를 관찰한 후 찾습니다. http 헤더는 실제로

Set-Cookie: testcookie=deleted; expires=Mon, 18-Jun-2007 02:42:33 GMT

입니다. 이는 실제로 setcookie("testcookie", '');가 쿠키 testcookie를 직접 삭제한다는 것을 보여줍니다. PHP 매뉴얼에는 이 상황에 대한 설명이 전혀 없습니다.

마지막으로, PHP 소스 코드를 보고 마침내 진실을 발견했습니다(오픈 소스입니다. 장점이 굉장합니다. 내부 내용이 불분명한 경우 소스 코드를 직접 확인하세요)

다음 코드는 ext/standard/의 99행 근처에서 찾을 수 있습니다. php5.20의 Linux 소스 코드 패키지에 있는 head.c.

if (value && value_len == 0) {
time_t t = time(NULL) - 31536001;
dt = php_format_date("D, d-M-Y H:i:s T", sizeof("D, d-M-Y H:i:s T")-1, t, 0 TSRMLS_CC);
sprintf(cookie, "Set-Cookie: %s=deleted; expires=%s", name, dt);
efree(dt);
} else {
sprintf(cookie, "Set-Cookie: %s=%s", name, value ? encoded_value : "");
if (expires > 0) {
strcat(cookie, "; expires=");
dt = php_format_date("D, d-M-Y H:i:s T", sizeof("D, d-M-Y H:i:s T")-1, expires, 0 TSRMLS_CC);
strcat(cookie, dt);
efree(dt);
}
}

소스 코드 표시에서 명확합니다. if (value && value_len == 0), value_len이 0

sprintf(cookie, "Set-Cookie: %s=deleted; expires=%s", name, dt);

이면 http 헤더가 전송됩니다. 브라우저에서 쿠키를 삭제합니다.

마지막으로 PHP에서

setcookie($cookiename, '');或者 setcookie($cookiename, NULL);

를 사용하면 쿠키가 삭제된다는 결론을 내릴 수 있습니다. 물론 이 매뉴얼에는 없습니다.

============================================== == =====================================

php 쿠키는 삭제/지울 수 없습니다. 만료되었나요?

오늘은 쿠키를 이용해 웹사이트에 로그인을 해봤습니다. 디버깅 후

 setcookie("username", "username", time()+1000,"/php100/");

를 이용해 사용자의 로그인 정보를 저장한 후,

setcookie("username", "", time()-3600);

를 이용해 로그아웃을 해보았는데요. 웹사이트를 구축하고 있으니 최대한 많은 브라우저와 호환되어야 합니다. 하하. 그래서 Firefox에서 테스트했는데 로그인할 때 모든 것이 잘 작동했습니다. 하지만 실행했을 때 문제가 발생했습니다. 로그아웃할 수 있는 방법은 없으며 사용자는 항상 로그인되어 있습니다. 그래서 IE와 Firefox에서 쿠키 기록의 차이를 확인해 보았는데, 테스트를 해보니 문득 깨달았습니다.

setcookie()의 네 번째 매개변수(법적 경로 매개변수)를 지정하지 않으면 기본적으로 현재 디렉터리가 합법적인 경로로 사용되는 것으로 나타났으며, 제가 테스트한 경로는 http://127.0.0.1 입니다. /php/rss2fla/data / log.php이므로 로그인 시 설정되는 쿠키 경로와 로그아웃 시 설정되는 쿠키 경로가 다릅니다.

IE는 Firefox보다 사용자 친화적입니다. ㅎㅎ, 경로를 지정할 때 현재 IP 아래에 동일한 이름으로 쿠키 변수를 덮어쓰게 됩니다. 하지만 FireFox는 더 엄격하여 새로운 변수가 생성됩니다...

위 내용은 PHP 쿠키를 지우는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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