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.
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.'/'); $_SESSION["username"] = 'tom'; ?>
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['admin'] = 'soft'; ?>
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!