> 백엔드 개발 > PHP 튜토리얼 > PHP에서 쿠키 인스턴스를 삭제하는 방법에 대한 자세한 설명

PHP에서 쿠키 인스턴스를 삭제하는 방법에 대한 자세한 설명

小云云
풀어 주다: 2023-03-21 06:52:01
원래의
1270명이 탐색했습니다.

이 글은 주로 PHP에서 쿠키 인스턴스를 삭제하는 방법에 대한 자세한 설명을 공유합니다. 먼저 관련 쿠키의 메커니즘을 살펴보겠습니다.

bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
로그인 후 복사

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

다음 예에서는 방금 설정한 쿠키를 삭제하는 방법을 보여줍니다.

//将过期时间设为一小时前setcookie("TestCookie", "", time() - 3600);
setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1);
?>
로그인 후 복사

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

나중에 PHP를 처음 접하는 친구가 프로그램에서 쿠키의 값을 비워두도록 설정하고 싶었는데 쿠키가 바로 삭제되었다고 하더군요. 당시 내 첫 번째 반응은 믿을 수 없다는 것이었으므로 테스트해 보았습니다.

setcookie("testcookie", '');
print_r($_COOKIE);
로그인 후 복사

결과는 $_COOKIE['testcookie']뿐만 아니라 전체 $_COOKIE 배열이 비어 있다는 것이었습니다. 그래서 Winsock을 사용하여 패킷을 캡처하고 반환된 http 헤더를 관찰한 결과 http 헤더가 "Set-Cookie: testcookie=deleted; 만료=Mon, 18-Jun-2007 02:42:33 GMT"로 나타났습니다. 이는 "setcookie("testcookie ", '');"를 의미하며 실제로 쿠키 testcookie를 직접 삭제하며 PHP 매뉴얼에는 이 상황에 대한 설명이 전혀 없습니다.

드디어 PHP 소스 코드를 읽고 마침내 진실을 찾았습니다. (이것이 오픈 소스의 장점입니다. 불분명한 내부 스토리가 있으면 소스 코드를 직접 확인하세요.)

다음과 같이 코드를 복사하세요.

if (value && value_len == 0) {
    /* 
     * MSIE doesn't delete a cookie when you set it to a null value
     * so in order to force cookies to be deleted, even on MSIE, we
     * pick an expiry date 1 year and 1 second in the past
     */
    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= delete; 만료=%s", 이름, dt);"는 쿠키를 삭제하기 위해 http 헤더를 브라우저로 보냅니다.

마지막으로 결론을 내릴 수 있습니다. PHP에서 "setcookie($cookiename, '');" 또는 "setcookie($cookiename, NULL);"을 사용하면 쿠키가 삭제되지만 물론 그러한 매뉴얼은 없습니다.

매우 간단하지 않나요? 때로는 PHP 소스 코드를 주의 깊게 읽어야 할 때도 있습니다.

관련 권장 사항:

쿠키를 가져오고 쿠키를 삭제하는 JavaScript에 대한 자세한 설명

php에서 쿠키를 삭제하는 방법

php 쿠키 클래스(쿠키 값 설정, 가져오기, 삭제)

위 내용은 PHP에서 쿠키 인스턴스를 삭제하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿