Maison >développement back-end >Problème PHP >Comment définir le délai d'expiration de la session en PHP

Comment définir le délai d'expiration de la session en PHP

PHPz
PHPzoriginal
2023-04-04 13:59:234168parcourir

Lors de l'écriture de sites Web PHP, les développeurs stockent souvent les données utilisateur dans Session pour implémenter des fonctions telles que le transfert d'informations entre pages et l'authentification des utilisateurs. Par défaut, les sessions PHP sont automatiquement effacées à la fin de la session ou expirent à la fermeture du navigateur. Cependant, les développeurs doivent parfois contrôler plus précisément le délai d’expiration de la session pour que la session reste valide pendant une certaine période. Cet article explique comment définir le délai d'expiration de la session en PHP.

  1. Concepts de base

Avant de commencer, nous devons comprendre les deux concepts suivants :

ID de session : chaque utilisateur se verra attribuer un ID de session unique lors de l'établissement d'une session avec le serveur, qui est utilisé pour identifier l'utilisateur. état de la session.

Variables de session : les variables de session font référence aux variables stockées côté serveur pendant la session. Elles sont utilisées pour stocker les données utilisateur.

  1. Comment modifier le délai d'expiration de la session

2.1. Modifier le fichier php.ini

Le délai d'expiration de la session PHP peut être défini dans le fichier de configuration php.ini, à l'aide du paramètre session.gc_maxlifetime, en secondes. Par défaut, sa valeur est de 1 440 secondes, soit 24 minutes. Vous pouvez le modifier en suivant les étapes ci-dessous :

  1. Ouvrez le fichier de configuration php.ini.
  2. Retrouvez la ligne suivante : session.gc_maxlifetime = 1440.
  3. Changez 1440 pour le délai d'expiration souhaité en secondes.
  4. Enregistrez et fermez le fichier php.ini.
  5. Redémarrez le serveur Web.

La modification de ce paramètre affectera le délai d'expiration de la session de tous les scripts PHP.

2.2. Définir dans le code

Si vous avez uniquement besoin de modifier l'heure d'expiration de la session d'une certaine page, ou de définir dynamiquement l'heure d'expiration de la session dans le code selon vos besoins, vous pouvez utiliser le code suivant :

session_start (); // Démarrer la session
$expireTime = 60*30; // Le délai d'expiration est de 30 minutes
$_SESSION['timeout'] = time() + $expireTime; Variable de session
?> ;

Dans le code, utilisez $_SESSION['timeout'] pour spécifier une variable de session liée à l'heure d'expiration. Il stocke la valeur de l'horodatage actuel (time()) plus l'heure d'expiration ($expireTime). Chaque fois que vous visitez la page, vous pouvez vérifier si cette variable a expiré. Si elle a expiré, appelez la fonction session_destroy() pour détruire la session.

2.2.1. En modifiant les paramètres du cycle de vie de la session

Vous pouvez également utiliser la fonction session_set_cookie_params() pour définir l'heure d'expiration de la session dans le code. Cette fonction peut accepter plusieurs paramètres, dont le plus important est le paramètre de cycle de vie de la session, qui détermine le délai d'expiration de la session.

Ce qui suit est un exemple :

session_start();
$expireTime = 60*30; // Le délai d'expiration est de 30 minutes
session_set_cookie_params($expireTime);
?>

Ce code will Le délai d'expiration de la session est fixé à 30 minutes.

  1. Autres notes

Que ce soit en modifiant le fichier php.ini, en le définissant dans le code, ou en le définissant via les paramètres du cycle de vie de la Session, il y a les notes suivantes :

  • L'heure d'expiration de la Session n'est pas absolument exact. Parce qu'il repose sur le mécanisme de récupération de place PHP, le délai d'expiration réel peut être incompatible avec le délai défini en raison de plusieurs facteurs.
  • Si vous utilisez une technologie d'équilibrage de charge multi-serveurs, vous devez vous assurer que les ID de session de tous les serveurs sont les mêmes, sinon des problèmes d'incohérence de session se produiront.

La session est une fonctionnalité très importante lors de l'écriture d'applications PHP. En définissant le délai d'expiration de la session, vous pouvez mieux protéger la sécurité des données utilisateur et éviter un gaspillage inutile des ressources du serveur.

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