Maison > développement back-end > Problème PHP > Comment définir la durée d'une session en php

Comment définir la durée d'une session en php

L
Libérer: 2023-03-01 09:24:02
original
2965 Les gens l'ont consulté

Comment définir la durée d'une session en php

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

1. Le client n'interdit pas les cookies

(1) Utilisez session_set_cookie_params() pour définir l'heure d'expiration de la session. Cette fonction est la session combinée 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;;
?>
Copier après la connexion

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.

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

(2) Utilisez setcookie Le () peut 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;;
?>
Copier après la connexion

Remarque : dans la fonction setcookie() de l'exemple de code ci-dessus, session_name est le nom de la session. session_id est l'identification de l'utilisateur client, car session_id est un nom unique généré aléatoirement, donc la session est relativement sûre. 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. Le client désactive les cookies

Lorsque le client désactive les cookies, le transfert entre les pages de session sera invalide. Vous pouvez imaginer que le client désactive les cookies en gros. 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 le supermarché où vous avez fait votre demande. Il existe plusieurs manières de résoudre ce problème :

(1) Rappelez aux utilisateurs que les cookies doivent être activés 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) Passez le session_id via la méthode GET sous la forme cachée.

(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é si vous rencontrez des fichiers de session qui ralentissent le serveur lors du développement de sites Web au niveau de l'entreprise. Nous introduisons ici la troisième méthode de transmission utilisant la méthode GET. L'exemple de code est le suivant Le code pour recevoir l'en-tête de la 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;;
?>
Copier après la connexion

Description : La session générera un session_id après avoir demandé la page. Si le cookie est désactivé, le session_id ne peut pas être transmis. Lors de la demande de la page suivante, un session_id sera régénéré, ce qui entraînera l'échec du passage de la session entre les pages

Tutoriel 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!

Étiquettes associées:
php
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal