Maison > Article > développement back-end > Comment PHP gère-t-il les cookies ?
Les cookies sont des fichiers texte stockés sur l'ordinateur du client et conservés à des fins de suivi. PHP prend en charge de manière transparente les cookies HTTP.
L'identification des utilisateurs récurrents implique trois étapes
Le script du serveur envoie un ensemble de cookies au navigateur. Comme l'âge, etc.
● Le navigateur stocke ces informations localement sur votre ordinateur pour une utilisation future
● La prochaine fois que le navigateur enverra une demande au serveur Web, il enverra ces informations de cookie au serveur, Le serveur utilise ces informations pour identifier l'utilisateur.
Ce chapitre vous apprendra comment paramétrer les cookies, comment y accéder et comment les supprimer.
Anatomie d'un cookie
Les cookies sont généralement définis dans les en-têtes HTTP (bien que JavaScript puisse également définir des cookies directement sur le navigateur). Un script PHP qui définit un cookie peut envoyer un en-tête qui ressemble à ceci (vu par le navigateur F12, réseau)
HTTP/1.1 200 OK Date: Fri, 04 Feb 2000 21:03:38 GMT Server: Apache/1.3.9 (UNIX) PHP/4.0b3 Set-Cookie: name=xyz; expires=Friday, 04-Feb-07 22:03:38 GMT; path=/; domain=jc2182.com Connection: close Content-Type: text/html
Comme vous pouvez le voir, l'en-tête Set-Cookie contient des paires nom-valeur, la date GMT, le chemin et domaine. Les noms et les valeurs seront codés en URL. Le champ d'expiration est l'instruction du navigateur pour supprimer le cookie après une heure et une date données. Si le navigateur est configuré pour stocker des cookies, ces informations seront conservées jusqu'à la date d'expiration. Si l'utilisateur pointe le navigateur vers une page correspondant au chemin et au domaine du cookie, il renverra le cookie au serveur. L'en-tête du navigateur peut ressembler à ceci
GET / HTTP/1.0 Connection: Keep-Alive User-Agent: Mozilla/4.6 (X11; I; Linux 2.2.6-15apmac ppc) Host: zink.demon.co.uk:1126 Accept: image/gif, */* Accept-Encoding: gzip Accept-Language: en Accept-Charset: iso-8859-1,*,utf-8 Cookie: name=xyz
Le script PHP peut alors accéder à la variable d'environnement $_COOKIE, qui contient tous les noms et valeurs des cookies.
Définir des cookies avec PHP
PHP fournit la fonction setcookie() pour définir des cookies. Cette fonction prend jusqu'à six paramètres et doit être appelée avant la balise . Cette fonction doit être appelée individuellement pour chaque ensemble de cookies.
setcookie(name, value, expire, path, domain, security);
Voici les détails de tous les paramètres
Quantity name - Définissez le nom du cookie.
Quantity Value - Définit la valeur de la variable nommée et correspond à ce que vous souhaitez réellement stocker.
● Expirer - Ceci spécifie l'heure dans le futur (en secondes) depuis 00:00:00 GMT le 1er janvier 1970. Passé ce délai, le cookie sera inaccessible. Si ce paramètre n'est pas défini, le cookie expirera automatiquement à la fermeture du navigateur Web.
gi Chemin - spécifie le répertoire dans lequel le cookie est valide. Une seule barre oblique permet au cookie d'être valide pour tous les répertoires.
domain - Ceci peut être utilisé pour spécifier des noms de domaine dans de très grands domaines et doit contenir au moins deux périodes de validité. Tous les cookies ne sont valables que pour l'hébergeur et le domaine où ils ont été créés.
● Sécurité - Peut être défini sur 1 pour spécifier que le cookie doit être envoyé uniquement via un transport sécurisé via HTTPS, sinon défini sur 0, ce qui signifie que le cookie peut être envoyé via HTTP standard.
L'exemple suivant créera deux cookies Nom et Âge, ces cookies expireront au bout d'une heure.
<?php setcookie("name", "John Watkin", time()+3600, "/","", 0); setcookie("age", "36", time()+3600, "/", "", 0); ?> <html> <head> <title>用PHP设置Cookies</title> </head> <body> <?php echo "设置 Cookies"?> </body> </html>
Astuce : La fonction time() renvoie l'horodatage actuel, qui est le nombre de secondes entre 0:00:00 le 1er janvier 1970 et le moment où le script est exécuté.
Ouvrez le navigateur pour accéder au script, puis appuyez sur F12 pour ouvrir le mode développeur, sélectionnez l'onglet Réseau, sélectionnez En-têtes, vous pouvez voir l'image suivante :
Accès aux cookies à l'aide de PHP
PHP offre de nombreuses façons d'accéder aux cookies. Le moyen le plus simple est d'utiliser la variable $_COOKIE. L'exemple suivant accédera à tous les cookies définis dans l'exemple ci-dessus.
<html> <head> <title>用PHP访问cookie</title> </head> <body> <?php echo $_COOKIE["name"]. "<br />"; echo $_COOKIE["age"] . "<br />"; ?> </body> </html>
Vous pouvez utiliser la fonction isset() pour vérifier si le cookie est défini. Si défini, alors sortie.
<html> <head> <title>用PHP访问cookie</title> </head> <body> <?php if(isset($_COOKIE["name"])) echo $_COOKIE["name"]. "<br />"; if(isset($_COOKIE["age"])) echo $_COOKIE["age"] . "<br />"; ?> </body> </html>
Supprimer des cookies avec PHP
Officiellement parlant, pour supprimer un cookie, vous devez simplement appeler setcookie() avec le paramètre name [c'est-à-dire que vous souhaitez supprimer ce nom. , en le définissant sur null], mais cela ne fonctionne pas toujours et il ne faut pas s'y fier. Le moyen le plus sûr est de définir une date d'expiration
/ Régler l'heure passée à 60 secondes avant l'heure actuelle/
<?php /* 设置过去时间为当前时间的之前的60秒 */ setcookie( "name", "", time()- 60, "/","", 0); setcookie( "age", "", time()- 60, "/","", 0); ?> <html> <head> <title>用PHP删除cookie</title> </head> <body> <?php echo "删除cookie" ?> </body> </html>
Apprentissage recommandé : Tutoriel 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!