Maison >développement back-end >tutoriel php >Contrôle de session en PHP
Le contenu de cet article est de partager avec vous le contrôle de peinture en PHP. Les amis dans le besoin peuvent s'y référer
Le protocole HTTP est la communication mutuelle entre le serveur WEB et protocole de navigateur, il s'agit d'un protocole sans état, c'est-à-dire que chaque requête HTTP est indépendante les unes des autres. Par conséquent, le protocole HTTP ne dispose pas de mécanisme intégré pour maintenir l’état entre deux transactions. Par exemple, lorsqu'un utilisateur demande une page puis en demande une autre, HTTP ne pourra pas nous dire si les deux requêtes proviennent du même utilisateur.
Dans les sites Web, nous avons souvent besoin de suivre une variable : en suivant les variables, nous pouvons établir des connexions entre plusieurs éléments de requête, puis afficher différents contenus et différentes pages en fonction de l'autorisation et de l'identité de l'utilisateur. Il s'agit d'une technologie de contrôle de session.
Les techniques de contrôle de session couramment utilisées sont Cookie
et Session
. En termes simples, Cookie détermine l'identité de l'utilisateur en enregistrant des informations côté client ; Session détermine l'identité de l'utilisateur en enregistrant des informations côté serveur.
Le cookie est un petit fichier texte inclus dans le message de requête HTTP et transmis entre le serveur Web et le navigateur. Le principe de fonctionnement du Cookie est le suivant :
Le serveur définit un champ Set-Cookie
dans le message de réponse HTTP et place les données du Cookie dans le champ Set-Cookie
avec le message HTTP. . Au navigateur ;
Après avoir reçu le message de réponse HTTP, le navigateur vérifie que le champ Set-Cookie
a une valeur et créera un fichier Cookie localement pour enregistrer les données
<?php setcookie("Cookie", "cookievalue", time()+3600);
ReceiveSupprimer
<?php echo $_COOKIE["Cookie"];Session
<?php #方法一:将值设为空 setcookie("Cookie", null); #方法二:将过期时间设为过去时间 setcookie("Cookie", "value" , time());
seesion_start()
session_start()
et autres paramètres dans php.ini). Deuxièmement, la session est enregistrée sous forme de fichier. Il y a un élément de configuration PHPSESSID
dans php.ini. Le chemin renseigné enregistrera tous les fichiers de session. Le format de dénomination des fichiers de session est : session.use_trans_sid
. Chaque fichier stocke les données d'une session. Enfin, les données enregistrées dans le fichier de session sont sérialisées, telles que : --session.save_path= ""
sess_[PHPSESSID的值]
cityID|i:0;cityName|s:3:"all";fanwe_lang|s:5:"zh-cn";fanwe_currency|a:4:{s:2:"id";s:1:"1";s:6:"name_1";s:9:"人民币";s:4:"unit";s:3:"¥";s:5:"radio";s:6:"1.0000";}_fanwe_hash__|s:32:"77c18770c6cb5d89444c407aaa3e8477";
Créer
Remarque : session_start() doit être appelé avant que le contenu du fichier HTML ne soit affiché//启动 session session_start(); //注册session变量,赋值为一个用户的名称 $_SESSION["username"] = "jochen"; //注册session变量,赋值为一个用户的ID $_SESSION["uid"] = 1;
Lire
<?php session_start(); echo $_SESSION["username"]; # # jochen echo $_SESSION["uid"]; # 1Il convient de noter que lorsqu'il y a de nombreux fichiers de session, des problèmes de performances de lecture et d'écriture I/Q se produiront. À l'heure actuelle, des systèmes de mise en cache tels que Memcached et Redis peuvent être utilisés.
<?php session_start(); unset($_SESSION["username"]); unset($_SESSION["uid"]);
Recommandations associées :Tableaux pour l'apprentissage 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!