Maison >développement back-end >tutoriel php >Explication détaillée du réglage de l'heure de session en php

Explication détaillée du réglage de l'heure de session en php

伊谢尔伦
伊谢尔伦original
2017-04-28 11:52:222744parcourir

Dans la plupart des forums, vous pouvez choisir le délai d'expiration lors de la connexion, comme économiser pendant une semaine, économiser pendant un mois, etc. À ce stade, vous pouvez définir le délai d'expiration de la connexion via Cookie. Il existe plusieurs manières principales de définir l'heure d'expiration de la session :

1 Le client n'interdit pas les cookies

(1) Utilisation session_set_cookie_params()Définit l'heure d'expiration de la session. Cette fonction combine Session avec Cookie pour définir l'heure d'expiration. Si vous souhaitez que la session expire au bout d'une minute, l'exemple de code est le suivant :

<?php
 $time = 1*60;                   //设置session失效时间
 session_set_cookie_params($time);      // 使用函数
 session_start();                 //初始化  session
 $_SESSION["username"] = &#39;tom&#39;;
?>
Remarque : session_set_cookie_params() doit être appelée avant session_start().

Remarque : Cette fonction est déconseillée et peut poser des problèmes sur certains navigateurs. Par conséquent, le délai d’expiration est généralement défini manuellement.

(2) Utilisez la fonction

setcookie() pour définir le délai d'expiration de la session. Pour que la session expire après une minute, l'exemple de code est le suivant :

<?php
 session_start();
 // session失效时间
 $time = 1*60;                    
 // 使用 setcookie 手动设置 session失效时间      
 setcookie(session_name(),session_id(),time()+$time.&#39;/&#39;);    
 $_SESSION["username"] = &#39;tom&#39;;
?>
Remarque : dans la fonction setcookie() de l'exemple de code ci-dessus, session_name est le nom de la session et session_id est l'identification de l'utilisateur client. Étant donné que session_id est un nom unique généré aléatoirement, la session est relativement. sûr. Le délai d'expiration est le même que celui du Cookie. Le dernier paramètre est facultatif et correspond au chemin où le Cookie est placé.

2. Désactivez les cookies sur le client

Lorsque le client désactive les cookies, le transfert entre les pages de session sera invalide. sur le client Imaginez une grande chaîne de supermarchés. Si vous demandez une carte de membre dans l'un des supermarchés, mais qu'il n'y a pas de connexion Internet entre les supermarchés, la carte de membre ne peut être utilisée que dans ce supermarché. Il existe plusieurs manières de résoudre ce problème :

(1) Rappelez aux utilisateurs qu'ils doivent activer les cookies avant de se connecter. C'est la pratique de nombreux forums.

(2) Définissez session.use_trans_sid =1 dans le fichier php.ini, ou activez l'option -enable-trans-sid lors de la compilation pour permettre à PHP de transmettre automatiquement session_id entre les pages.

(3) Transmettez le session_id sous la forme cachée via la méthode GET.

(4) Utilisez un fichier ou une base de données pour stocker session_id et appelez-le manuellement lors du transfert entre les pages.

La deuxième méthode ci-dessus ne sera pas présentée en détail car les utilisateurs ne peuvent pas modifier le fichier php.ini sur le serveur. Dans la troisième méthode, nous ne pouvons pas utiliser Cookie pour définir le délai d'expiration, mais le statut de connexion ne change pas. Le quatrième et le plus important peut être utilisé lors du développement de sites Web au niveau de l'entreprise si vous rencontrez des

fichiers de session qui ralentissent le serveur. Nous introduisons ici la troisième méthode de transmission en utilisant la méthode

GET . L'exemple de code est le suivant. Le code pour recevoir l'en-tête de page :

<?php
  $session_name = session_name();        //取得 session 名称
  $session_id = $_GET[$session_name];    // 取得 session_id GET方式
  session_id($session_id);               // 关键步骤
  session_start();
  $_SESSION[&#39;admin&#39;] = &#39;soft&#39;;
?>
Description : La session est après la demande. page. Un session_id sera généré. Si le cookie est désactivé à ce moment, le session_id ne peut pas être transmis. Lorsque la page suivante est demandée, un session_id sera régénéré, ce qui entraînera l'échec du passage de la session entre les pages.

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