Maison  >  Article  >  développement back-end  >  Explication détaillée de l'application de la session php

Explication détaillée de l'application de la session php

墨辰丷
墨辰丷original
2018-05-24 16:33:201880parcourir

Explication détaillée de l'application de la session php

Cet article présente principalement des informations pertinentes sur l'application de la session php en détail. Les amis qui en ont besoin peuvent se référer à

Application avancée de session php.

La session est très importante dans la technologie Web. Étant donné que la page Web est un programme de connexion sans état, l'état de navigation de l'utilisateur ne peut pas être connu. Grâce à la session, les informations pertinentes de l'utilisateur peuvent être enregistrées pour confirmation lorsque l'utilisateur soumet à nouveau une demande au serveur Web à ce titre.

Par exemple : lorsqu'un utilisateur navigue sur un site e-commerce, s'il n'y a pas de session, l'utilisateur doit saisir le mot de passe du compte à chaque fois qu'il navigue.

Recommandations de sujets connexes : session php (y compris des photos, des vidéos, des cas)

1, session fichiers temporaires

Dans le serveur, si toutes les sessions utilisateur sont enregistrées dans le répertoire temporaire, la sécurité et l'efficacité du serveur seront réduites. L'ouverture d'un site stocké sur le serveur sera très lente.

L'utilisation de la fonction PHP session_save_path() pour stocker les fichiers temporaires de session peut atténuer les problèmes de réduction de l'efficacité du serveur et de lenteur d'ouverture du site causés par le stockage de fichiers temporaires.

L'exemple de code est le suivant :

<?php
$path ="./tmp/";    //设置session存储的路径
session_save_path($path);
session_start();
$_SESSION[&#39;userName&#39;]=true;
?>

Remarque

session_save_path() doit être exécuté avant session_start().

2. Mise en cache de session

La mise en cache de session consiste à stocker temporairement le contenu de la page Web dans le dossier Fichiers Internet temporaires du client IE, et la durée du cache peut être réglé.

Le cache de session utilise la fonction session_cache_limiter(), dont la syntaxe est la suivante :

string session_cache_limiter([string cache_limiter]);

Le paramètre cache_limiter est public ou privé. La session Collègues ne se déroule pas côté serveur, mais côté client. Non affiché sur le serveur.

Pour définir la durée du cache, utilisez la fonction session_cache_expire() La syntaxe est la suivante :

int session_cache_expire([int new_cahche_expire]);

Le paramètre new_cahche_expire est le numéro de durée du cache de session, en minutes.

Remarque :

Ces deux fonctions de session doivent être exécutées avant la fonction session_start()

Exemple de page de cache de session Le code est le suivant :

<?php

session_cache_limiter("private");
$cache_limit =session_cache_limiter();   //开启客户端缓存
echo "缓存限制为:".$cache_limit."\n";
session_cache_expire(30);
$cache_expire = session_cache_expire();  //设定客户端缓存时间
echo "客户端缓存时间为:".$cache_expire."分钟\n";
session_start();

?>

Les résultats d'exécution sont les suivants :

Explication détaillée de lapplication de la session php

3, Stockage de la base de données de session

Le stockage de la base de données de session en PHP est principalement implémenté via la fonction session_set_save_handler(). La syntaxe spécifique est la suivante :
bool session_set_save_handler(string open,string close,string read,string write,string destroy,string gc

Explication détaillée de lapplication de la session php
Les six paramètres (fonctions) sont divisés en packages ci-dessous. Après avoir appris la programmation orientée objet, tout le monde aura une compréhension plus claire.


(1) Encapsulez la fonction session_open(), le code est le suivant :

function _session_open($save_path,$session_name){
global $handle;
$handle =mysql_connect(&#39;localhost&#39;,&#39;root&#39;,&#39;root&#39;)or die(&#39;数据库连接失败!&#39;);
mysql_select_db(&#39;db_database11&#39;,$handle)or die(&#39;数据库不存在&#39;);
return(true);
}
(2) Encapsulez la fonction session_close(), le code est le suivant :

function _session_close(){
global $handle;
mysql_close($handle);
return(true);
}
(3) Encapsulez la fonction session_read(), définissez l'horodatage UNIX de l'heure actuelle dans la fonction et recherchez la carte de visite et le contenu de la session en fonction de $key. Le code est le suivant :

function _session_read($key){
golbal $handle;     //全局变量$handle 连接数据库
$time =time();     //设定当前时间
$sql ="select session_data from tb_session where session_key = &#39;$key&#39; and session_time>&#39;$time&#39;";
$result =mysql_query($ssql,$handle);
$row =mysql_fetch_array($result);
if($row){
return($row[&#39;session_data&#39;]);
}else{
return(false);
}
}
(4) Encapsulez la fonction session_write(). La fonction définit le délai d'expiration de la session et trouve le nom et le contenu de la session si le résultat de la requête est vide. . Insérez ensuite la session de la page dans la base de données en fonction de l'ID de session, du nom de session et de l'heure d'expiration. Si le résultat de la requête n'est pas vide, modifiez les informations de stockage de session dans la base de données en fonction de $key. Le code est le suivant :

function _session_write($key,$data){
global $handle;
$time = 60*60;
$lapse_time =time()+$time;   //得到UNIX时间戳
$sql = "select session_data from tb_session where session_key =&#39;$key&#39; and session_time>$lapse_time";
$result =mysql_query($sql,$handle);
if(mysql_num_rows($result)==0){  //没有结果
$sql ="insert into tb_session values(&#39;$key&#39;,&#39;$data&#39;,$lapse_time)";
$result =mysql_query($sql,$handle);
}else{
$sql ="update tb_session set session_key=&#39;$key&#39;,session_data =&#39;$data&#39;,session_time =$lapse_time where session_key =&#39;$key&#39;";
$result =mysql_query($sql,$handle);
}
return($result);
}
(5) Encapsulez session_destroy() et supprimez Sessin dans la base de données selon $key. Le code est le suivant :

function _session_destroy(){
global $handle;
$sql ="delete from tb_session where session_key =&#39;$key&#39;";
$result =mysql_query($sql,$handle);
}
(6 ) Encapsulez session_gc() et supprimez-le en fonction de $key. Le délai d'expiration de la session supprime la session expirée. L'exemple de code est le suivant :

functin _session_gc($expiry_time){
global $handle;
$sql ="delete from tb_session where session_expiry_time<$expiry_time";
$result =mysql_query($sql,$handle);
return($result);
}
Je n'exécuterai pas le code spécifique, je vais le démontrer. quand j'aurai fini d'apprendre la programmation orientée objet.

Ce qui précède représente l’intégralité du contenu de cet article, j’espère qu’il sera utile à l’étude de chacun.

Recommandations associées :

Explication détaillée de la façon d'utiliser le session-cookie avec PHP et codeigniter

Parfait Résoudre le problème d'échec de session lors de l'accès à ajax

Explication détaillée de la méthode de stockage de PHPSession dans redis/redis

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn