>백엔드 개발 >PHP 문제 >PHP에서 쿠키를 삭제하는 방법

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

藏色散人
藏色散人원래의
2020-11-05 11:19:082145검색

PHP에서 쿠키를 삭제하는 방법: 1. "setCookie("name","",time()-60);"을 통해 단일 쿠키를 삭제합니다. 2. 배열을 탐색하기 위해 foreach를 사용하여 여러 쿠키를 삭제합니다.

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

추천: "PHP 동영상 튜토리얼"

php 쿠키 삭제

php 쿠키를 일괄 삭제하는 간단한 방법

코드는 다음과 같습니다.

<?php
//删除单个cookie:键值设置为空、时间设置为过期了的时间
setCookie("name","",time()-60);
//删除多个cookie,采用遍历数组方式
foreach($_COOKIE as $key=>$value){
 setCookie($key,"",time()-60);
}
?>

지식 포인트: 삭제하는 경우 웹사이트의 모든 쿠키 모든 쿠키가 삭제되면 웹사이트의 쿠키를 저장하는 파일도 삭제됩니다. 쿠키 중 하나만 삭제되면 파일에 있는 쿠키 정보만 삭제됩니다.

PHP 쿠키 사용

1. 쿠키 설정

PHP는 SetCookie 함수를 사용하여 쿠키를 설정합니다. 주목해야 할 한 가지 점은 쿠키는 HTTP 프로토콜 헤더의 일부이며 브라우저와 서버 간에 정보를 전송하는 데 사용된다는 것입니다. 따라서 HTML 파일 자체에 속한 콘텐츠가 출력되기 전에 쿠키 기능을 호출해야 합니다.

SetCookie 함수는 쿠키를 정의하고 이를 HTTP 헤더 끝에 추가합니다. SetCookie 함수의 프로토타입은 다음과 같습니다.

int SetCookie(string name, string value, int expire, string path, string domain, int secure);

이름을 제외한 모든 매개 변수는 선택 사항입니다. 세 가지 매개변수 value, path 및 domain은 빈 문자열로 대체될 수 있으며 이는 설정되지 않았음을 나타냅니다. 만료 및 보안 매개변수는 숫자이며 0으로 표시될 수 있습니다. 만료 매개변수는 time() 또는 mktime() 함수를 사용하여 초 단위로 얻을 수 있는 표준 Unix 타임스탬프입니다.

secure 매개변수는 이 쿠키가 암호화된 HTTPS 프로토콜을 통해 네트워크를 통해 전송되는지 여부를 나타냅니다.

현재 설정된 쿠키는 즉시 적용되지 않고 다음 페이지까지 표시되지 않습니다. 이는 쿠키가 설정된 페이지에서 서버에서 클라이언트의 브라우저로 전달되고 브라우저가 쿠키를 변경할 수 있기 때문입니다. 클라이언트의 컴퓨터가 검색되어 서버로 반환되는 이유는 다음 페이지에 나와 있습니다.

같은 페이지에 쿠키를 설정하는 것은 사실 뒤에서 앞으로 이루어지므로 새 쿠키를 삽입하기 전에 쿠키를 삭제하려면 먼저 삽입문을 작성한 다음 삭제문을 작성해야 합니다. 그렇지 않으면 원하지 않을 수도 있습니다. 결과.

몇 가지 예를 살펴보겠습니다.

간단함:

SetCookie("MyCookie", "Value of MyCookie");

만료 시간 포함:

SetCookie("WithExpire", "Expire in 1 hour", time()+3600);//3600秒=1小时

모든 것:

SetCookie("FullCookie", "Full cookie value", time()+3600, "/forum", ".phpuser.com", 1);

여기서 설명할 사항이 한 가지 더 있습니다. 예를 들어 귀하의 사이트에는 여러 개의 다른 디렉토리가 있습니다. 경로 없이 쿠키만 사용하는 경우 한 디렉터리의 페이지에 설정된 쿠키는 다른 디렉터리의 페이지에서 볼 수 없습니다. 즉, 쿠키는 경로 지향적입니다. 실제로 경로를 지정하지 않더라도 웹 서버는 자동으로 현재 경로를 브라우저에 전달하며, 경로를 지정하면 서버는 강제로 설정된 경로를 사용하게 됩니다. 이 문제를 해결하는 방법은 SetCookie를 호출할 때 경로와 도메인 이름을 추가하는 것입니다. 도메인 이름의 형식은 "www.phpuser.com" 또는 ".phpuser.com"일 수 있습니다.

SetCookie 함수의 값 부분은 전달 시 자동으로 인코딩됩니다. 즉, 값의 값이 "test value"인 경우 전달 시 URL의 방법과 동일하게 "test%20value"가 됩니다. . 물론, 이는 프로그램에 투명합니다. 왜냐하면 PHP는 쿠키 값을 수신할 때 자동으로 디코딩하기 때문입니다.

동일한 이름으로 여러 쿠키를 설정하려면 배열을 사용하세요. 방법은

SetCookie("CookieArray[]", "Value 1");
SetCookie("CookieArray[]", "Value 2");

또는

SetCookie("CookieArray[0]", "Value 1");
SetCookie("CookieArray[1]", "Value 2");

2입니다.

PHP는 쿠키 수신 및 처리를 매우 잘 지원합니다. 완전히 자동입니다. FORM 변수와 동일한 원리로 매우 간단합니다.

예를 들어 MyCookier라는 쿠키를 설정하면 PHP는 웹 서버가 수신한 HTTP 헤더에서 이를 자동으로 분석하여 $myCookie라는 일반 변수와 같은 변수를 형성합니다. . 배열에도 동일하게 적용됩니다. 또 다른 방법은 PHP의 전역 변수 $HTTP_COOKIE_VARS 배열을 참조하는 것입니다.

예제는 다음과 같습니다. (이전 페이지에서 설정되었으며 여전히 유효하다고 가정)

echo $MyCookie;
echo $CookieArray[0];
echo count($CookieArray);
echo $HTTP_COOKIE_VARS["MyCookie"];

그렇게 간단합니다.

3. 쿠키 삭제

기존 쿠키를 삭제하는 방법은 두 가지가 있습니다.

먼저 이름 매개변수만 사용하여 SetCookie를 호출하면 이 이름의 쿠키가 관련 컴퓨터에서 삭제됩니다. 쿠키 만료 시간을 time() 또는 time()-1로 설정하면 페이지를 탐색한 후 쿠키가 삭제됩니다(실제로 만료됨).

쿠키가 삭제되더라도 해당 값은 현재 페이지에서 여전히 유효하다는 점에 유의하세요.

4. 쿠키 사용 제한

먼저 HTML 파일의 내용이 출력되기 전에 설정해야 합니다.

둘째, 브라우저마다 쿠키를 일관성 없이 처리하여 때로는 잘못된 결과가 발생할 수 있습니다. 예를 들어, MS IE+SERVICE PACK 1은 도메인 이름과 경로가 있는 쿠키를 올바르게 처리할 수 없으며, Netscape Communicator 4.05 및 MS IE 3.0은 경로와 시간이 없는 쿠키를 올바르게 처리할 수 없습니다. MS IE 5의 경우 도메인명, 경로, 시간이 포함된 쿠키를 처리할 수 없는 것 같습니다. 이것은 제가 이 사이트의 페이지를 디자인하면서 발견한 것입니다.

세 번째 제한은 클라이언트 측에 있습니다.

브라우저에서 생성할 수 있는 최대 쿠키 수는 30개이며, 각 웹 사이트에서 설정할 수 있는 총 쿠키 수는 20개를 초과할 수 없습니다.

PHP 쿠키 삭제 방법

首先我们看一下php手册中关于删除cookie的说明

------以下引用php手册内容--------------

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

要删除 cookie 需要确保它的失效期是在过去,才能触发浏览器的删除机制。

下面的例子说明了如何删除刚才设置的 cookie: 例子 2. setcookie() 删除

例子

// 将过期时间设为一小时前
setcookie("TestCookie", "", time() - 3600);
setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1);
----------------引用结束--------------------------

删除一个cookie的方法就是把这个cookie的有效期设置为当前时间以前,这

也是几乎所有php程序员都会这么做。

后来一个初接触php的朋友告诉我,他在程序中本想把一个cookie的值设置为空,结果导致这个cookie直接被删除。我当时的第一反应是不相信,于是测试了一下

setcookie("testcookie", &#39;&#39;);
print_r($_COOKIE);

结果果然是整个$_COOKIE数组都是空的,而非仅仅$_COOKIE['testcookie']为空.于是用winsock抓包,观察返回的http头,发现http头竟然是

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

这说明setcookie("testcookie", '');的的确确是将testcookie这个cookie直接删除.而关于这种情况在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);

会发送删除cookie的http头给浏览器.

最后我们可以得出结论,在php中使用

setcookie($cookiename, &#39;&#39;);或者 setcookie($cookiename, NULL);

都会删除cookie,当然这些手册中并没有。

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

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