En PHP, vous pouvez utiliser la fonction setcookie() pour supprimer les cookies. Il vous suffit de définir le deuxième paramètre de la fonction sur vide, ou de définir le troisième paramètre sur une valeur inférieure à l'heure actuelle du système. . Syntaxe "setcookie($cookiename,'');", "setcookie($cookiename, NULL);" ou "setcookie($cookiename, "", time() - 3600);".
L'environnement d'exploitation de cet article : système Windows 7, version PHP 8, ordinateur DELL G3.
php delete cookie
Regardons d'abord le mécanisme des cookies associés.
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
Pour supprimer un cookie, vous devez vous assurer que sa date d'expiration est située dans le passé pour déclencher le mécanisme de suppression du navigateur.
L'exemple suivant illustre comment supprimer le cookie que vous venez de définir :
//将过期时间设为一小时前 setcookie("TestCookie", "", time() - 3600); setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1); ?>
La façon de supprimer un cookie est de définir la période de validité du cookie avant l'heure actuelle, ce qui est presque tous les programmeurs PHP le font.
Plus tard, un ami qui était nouveau sur PHP m'a dit qu'il voulait définir la valeur d'un cookie à vide dans le programme, mais le cookie a été supprimé directement. Ma première réaction à l'époque a été que je n'y croyais pas, alors je l'ai testé :
setcookie("testcookie", ''); print_r($_COOKIE);
Le résultat a été que tout le tableau $_COOKIE était vide, pas seulement $_COOKIE['testcookie']. J'ai donc utilisé Winsock pour capturer le paquet et observé l'en-tête http renvoyé. J'ai découvert que l'en-tête http s'est avéré être "Set-Cookie: testcookie=deleted; expires=Mon, 18-Jun-2007 02:42:33 GMT". , ce qui signifie "setcookie("testcookie ", '');" supprime en effet directement le cookie testcookie, et il n'y a aucune explication dans le manuel PHP sur cette situation.
Enfin, lisez le code source php et découvrez enfin la vérité (c'est l'avantage de l'open source, s'il y a une histoire intérieure peu claire, vérifiez simplement le code source directement).
Le code suivant se trouve près de la ligne 99 de ext/standard/head.c dans le package source Linux php5.20 :
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); } }
Le code source indique clairement "if (value && value_len == 0)", lorsque "value_len" est 0, "sprintf(cookie, "Set-Cookie: %s=deleted; expires=%s", name, dt);" enverra l'en-tête http pour supprimer le cookie. navigateur.
Enfin, nous pouvons conclure que l'utilisation de "setcookie($cookiename, '');" ou "setcookie($cookiename, NULL);" en php supprimera les cookies, mais bien sûr, ce n'est pas dans ces manuels.
(Recommandé : "Tutoriel vidéo PHP")
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!