Précédent   Forum des professionnels en informatique > PHP > Langage > Sessions
Sessions Forum d'entraide sur les sessions avec PHP. Avant de poster -> FAQ sessions, Cours sessions et Sources sécurité
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 24/03/2011, 21h26   #1
Invité régulier
 
Inscription : août 2010
Messages : 53
Détails du profil
Informations forums :
Inscription : août 2010
Messages : 53
Points : 5
Points : 5
Par défaut comment faire expirer une session ?

slt tlm,

j'essaye d'ecrire quelques lignes qui me permettent de gerer les session cad je veux qu'apres un certain temps et si l utilisateur ne touche rien sur le site, sa session s'expire automatiquement et affiche le message 'votre session est expiré' et la il doit se reconnecter.

j'ai trouvé quelque chose sur le net mais malheureusement ça fonctionne pas toujours .

quelqu'un peut m'aider?
molo1987 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/03/2011, 21h28   #2
Modérateur
 
Inscription : septembre 2010
Messages : 7 103
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 103
Points : 8 466
Points : 8 466
avec le lifetime
http://www.php.net/manual/fr/functio...kie-params.php

ensuite il faudrait checker tout les X temps en AJAX voir si la session est active
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 25/03/2011, 15h09   #3
Invité régulier
 
Inscription : août 2010
Messages : 53
Détails du profil
Informations forums :
Inscription : août 2010
Messages : 53
Points : 5
Points : 5
j'aimerais bien la faire avec les session sans passer par les cookies

j'ai essayer ce code mais le probleme il me derige toujours dans la page login.php

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<?php
function valide_login () {
            /* Mise en place d’un délai pour une session de connexion. */
            /* L’expiration est de 10 minutes par défaut (600 secondes). */
            $delai = 600;
            $_SESSION["v"]["expires_by"] = time() + $delai;
       }
 
       function verif_login () {
                /* Vérifie le délai d’expiration de la session */
                  $expiration = intval($_SESSION["v"]["expires_by"]);
                  if (time() < $expiration) {
                       /* La session est toujours en cours ; on réinitialise son délai.*/
                       valide_login();
                       return true;
                  } else {
				      /* la session a expiré ; on supprime la variable de session. */
                      unset($_SESSION["v"]["expires_by"]);
                      return false;
 
                  }
	 }
 
           if (verif_login()!= true) {
                header("Location: login.php");
     }
?>
molo1987 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/03/2011, 15h23   #4
Membre chevronné
 
Homme Taoufiq Ben
Développeur Web
Inscription : mai 2009
Messages : 456
Détails du profil
Informations personnelles :
Nom : Homme Taoufiq Ben
Âge : 25
Localisation : Maroc

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Multimédia et Internet

Informations forums :
Inscription : mai 2009
Messages : 456
Points : 639
Points : 639
Est ce que tu met avant de crée et d'appelé la session
m4riachi est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/03/2011, 16h06   #5
Modérateur
 
Inscription : septembre 2010
Messages : 7 103
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 103
Points : 8 466
Points : 8 466
t'es en trans_id ? puisqu’une session génère toujours un cookie
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/03/2011, 17h28   #6
Invité régulier
 
Inscription : août 2010
Messages : 53
Détails du profil
Informations forums :
Inscription : août 2010
Messages : 53
Points : 5
Points : 5
Citation:
Envoyé par m4riachi Voir le message
Est ce que tu met avant de crée et d'appelé la session
oui bien sure mais e c pas si l emplacement du codes est correct;j'ai deux page
page 1
Code :
1
2
3
4
5
6
7
<?php
      require('f.php'); 
	 session_start();
	 if (verif_login()!= true) {
                header("Location: login.php");
     }
?>
et la page o il y a mes fonctions

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php
function valide_login () {
            /* Mise en place d’un délai pour une session de connexion. */
            /* L’expiration est de 10 minutes par défaut (600 secondes). */
            $delai = 600;
            $_SESSION["v"]["expires_by"] = time() + $delai;
       }
 
       function verif_login () {
                /* Vérifie le délai d’expiration de la session */
                  $expiration = intval($_SESSION["v"]["expires_by"]);
                  if (time() < $expiration) {
                       /* La session est toujours en cours ; on réinitialise son délai.*/
                       valide_login();
                       return true;
                  } else {
				      /* la session a expiré ; on supprime la variable de session. */
                      unset($_SESSION["v"]["expires_by"]);
                      return false;
 
                  }
	 }
?>
molo1987 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/03/2011, 19h03   #7
Membre chevronné
 
Homme Taoufiq Ben
Développeur Web
Inscription : mai 2009
Messages : 456
Détails du profil
Informations personnelles :
Nom : Homme Taoufiq Ben
Âge : 25
Localisation : Maroc

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Multimédia et Internet

Informations forums :
Inscription : mai 2009
Messages : 456
Points : 639
Points : 639
Mets la session_start avant le require
Code :
1
2
3
4
5
6
7
<?php
session_start();
require('f.php'); 
if (verif_login()!= true) {
header("Location: login.php");
}
?>
m4riachi est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 23h04.


 
 
 
 
Partenaires

Hébergement Web