> 백엔드 개발 > PHP 튜토리얼 > PHP에서 쿠키를 삭제하는 방법

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

怪我咯
풀어 주다: 2023-03-13 10:40:02
원래의
1012명이 탐색했습니다.

이 글에서는 쿠키 유효 기간을 설정하거나 비워두는 쿠키 삭제 방법을 간략하게 소개합니다. 이는 매우 실용적인 팁이며 여기 계신 모든 분들께 권장됩니다.

먼저 관련 쿠키의 메커니즘을 살펴보겠습니다.

코드는 다음과 같습니다.

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

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

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

코드는 다음과 같습니다.

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

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

나중에 PHP를 처음 접하는 친구가 프로그램에서 쿠키의 값을 비워두도록 설정하고 싶었는데 쿠키가 바로 삭제되었다고 하더군요. 당시 내 첫 반응은 믿기지 않는다는 것이었기 때문에 테스트해봤다.

코드는 다음과 같다:

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

결과는 $_COOKIE

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

에는 이 상황에 대한 설명이 전혀 없습니다.

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

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

코드는 다음과 같습니다.

if (value && value_len == 0) {
    /* 
     * MSIE doesn&#39;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=deleted;expires=%s", name, dt);"는 쿠키를 삭제하기 위해 http 헤더를 보냅니다. 브라우저.

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

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

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

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