Maison >développement back-end >tutoriel php >Une brève analyse du réglage de l'heure de 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"] = 'tom'; ?>
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 au bout d'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.'/'); $_SESSION["username"] = 'tom'; ?>
Explication : In. l'exemple de code ci-dessus Dans la fonction setcookie(), 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û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 comme une grande chaîne de supermarchés. des supermarchés Si vous demandez une carte de membre dans un supermarché, 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 l'avez demandée. 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é 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 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['admin'] = 'soft'; ?>
Description : La session générera un session_id après avoir demandé la page. Si les cookies sont désactivés, 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!