Apprendre php session peut être utilisé dans de nombreux endroits, comme par exemple pour créer une fonction de connexion en arrière-plan. Il est en fait très simple de faire en sorte que le programme mémorise la session de l'utilisateur. Vous comprendrez après avoir lu l'article suivant.
L'utilisation d'une session PHP est en fait très simple. Elle peut enregistrer les données soumises par l'utilisateur dans une session en tant que variable globale et générer un session_id unique afin d'éviter toute confusion et dans le même navigateur. le même site ne peut avoir qu'un seul session_id. Voyons comment utiliser session.
Comment utiliser session, tout ce qui concerne la session doit être appelé avant function session_start();
Attribuer une valeur à la session est très simple, comme :
Le code est le suivant :
<?php Session_start(); $Name = "这是一个Session例子"; Session_Register("Name");//注意,不要写成:Session_Register("$Name"); Echo $_SESSION["Name"]; //之后$_SESSION["Name"]为"这是一个Session例子" ?>
Après php4.2, vous pouvez directement attribuer une valeur à la session :
Le code est le suivant :
<?PHP Session_Start(); $_SESSION["name"]="value"; ?>
Annulez la session comme ceci :
Le code est le suivant :
<?php session_start(); session_unset(); session_destroy(); ?>
Lire la session
La variable $_SESSION intégrée de PHP peut accéder facilement à la variable de session définie.
Le code est le suivant :
<?php session_start(); echo "登记的用户名为:".$_SESSION["username"]; //输出 登记的用户名为:nostop ?>
Vérifiez si la variable est enregistrée en tant que variable de session session_is_registered
Syntaxe : boobean session_is_registered(string name);
Cette fonction peut vérifier si la variable spécifiée a été enregistrée dans la session, le nom du paramètre est le nom de la variable à vérifier. En cas de succès, la valeur logique true est renvoyée.
Le code est le suivant :
<?php session_start(); if(!session_is_registered("gender")){ //判断当前会话变量是否注册 session_register("gender"); //注册变量 } $gender="女"; echo $_SESSION['gender']; //女 ?>
Accéder au nom de la session en cours nom_session
Syntaxe : boolean session_name(string [name]);
Cette fonction peut obtenir ou redéfinir le nom de la session en cours. S'il n'y a pas de nom de paramètre, cela signifie obtenir le nom de la session actuelle, et ajouter le paramètre signifie définir le nom de session sur le nom du paramètre.
Le code est le suivant :
<?php $sessionName = session_name(); //取得当前 Session 名,默认为 PHPSESSID $sessionID = $_GET[$sessionName]; //取得 Session ID session_id($sessionID); //使用 session_id() 设置获得的 Session ID ?>
Accéder au numéro d'identification de la session en cours session_id
Syntaxe : boolean session_id(string [id]);
Cette fonction peut obtenir ou réinitialiser le numéro d’identification de la session actuellement stockée. S'il n'y a pas d'identifiant de paramètre, cela signifie que seul le numéro d'identification de la session en cours est obtenu. Si le paramètre est ajouté, cela signifie que le numéro d'identification de la session est défini sur l'identifiant nouvellement spécifié.
Définir la durée de vie de la Session
Le code est le suivant :
<?php session_start // 保存一天 $lifeTime = 24 * 3600; setcookie(session_name(), session_id(), time() + $lifeTime, "/"); ?>
session_set_cookie_params : Pour définir la durée de vie de la Session, cette fonction doit être appelée avant le La fonction session_start() est appelée.
Si le client utilise IE 6.0, la fonction session_set_cookie_params(); aura quelques problèmes pour définir les cookies, nous appelons donc toujours la fonction setcookie manuellement pour créer des cookies.
Le code est le suivant :
<?php // 保存一天 $lifeTime = 24 * 3600; session_set_cookie_params($lifeTime); session_start(); $_session["admin"] = true; ?>
Définir le chemin de sauvegarde du fichier Session
session_save_path() : doit être appelé avant que la fonction session_start() soit appelée .
Le code est le suivant :
<?php // 设置一个存放目录 $savePath = "./session_save_dir/"; // 保存一天 $lifeTime = 24 * 3600; session_save_path($savePath); session_set_cookie_params($lifeTime); session_start(); $_session["admin"] = true; ?>
<?php session_start(); //启动Session $username='nostop'; session_register('username'); //注册一个名为username变量 echo '登记的用户:'.$_SESSION['username']; //登记的用户:nostop 读取Session变量 $_SESSION['age']=23; //声明一个名为age的变量,并赋值 echo '年龄:'.$_SESSION['age']; //年龄:23 session_unregister('username'); //注销Session变量 echo $_SESSION['username']; //空 echo $_SESSION['age'];//23 unset($_SESSION['age']); //注销Session变量 echo '登记的用户:'.$_SESSION['username']; //空 echo '年龄:'.$_SESSION['age']; //空 ?>
Remarque :
1 : Il ne peut y avoir de sortie avant d'appeler Session_Start() Par exemple. , ce qui suit est faux .
1 ligne
2 lignes3 lignes Session_Start();//Il y avait déjà une sortie dans la première ligne
4 lignes....
Ligne 5?>
Astuce 1 :
Chaque fois que ".....en-têtes déjà envoyés....." apparaît, c'est Session_Start() Les informations ont été envoyées à le navigateur avant.
Supprimez la sortie et ce sera normal (Cette erreur se produira également dans COOKIE, et la raison de l'erreur est la même)
Astuce 2 :
Si votre Session_Start() met In dans une instruction de boucle, et il est difficile de déterminer où les informations ont été précédemment affichées dans le navigateur, vous pouvez utiliser la méthode suivante :
line 1Ob_Start(); ?>
....Voici votre programme...
2 : Quelle est l'erreur
Attention : session_start(): open(/tmpsess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) a échoué :....
Parce que vous n'avez pas spécifié le chemin de stockage du fichier de session.
Solution :
(1) Créez le dossier tmp sur le lecteur c
(2) Ouvrez-le php.ini, recherchez session.save_path, remplacez-le par session.save_path= "c:/tmp"
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!