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