IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

redirectionner une session


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Novembre 2005
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 22
    Par défaut redirectionner une session
    j'utilise un gestionnaire de session. Lors de la destruction automatique de la session j'aimerais rediriger l'utilisateur vers une page ou il devra rentrer ses parametres de connection à nouveau.
    Voici le code du gestionnaire de session:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
     
    $SESS_DBHOST = "localhost";            /* database server hostname */ 
    $SESS_DBNAME = "mabase";    /* database name */ 
    $SESS_DBUSER = "root";            /* database user */ 
    $SESS_DBPASS = "";                    /* database password */ 
     
    $SESS_DBH = ""; 
    //$SESS_LIFE = get_cfg_var("session.gc_maxlifetime"); 
    $SESS_LIFE = 3600; 
     
    function sess_open($save_path, $session_name) { 
        global $SESS_DBHOST, $SESS_DBNAME, $SESS_DBUSER, $SESS_DBPASS, $SESS_DBH; 
     
        if (! $SESS_DBH = mysql_pconnect($SESS_DBHOST, $SESS_DBUSER, $SESS_DBPASS)) { 
            echo "<li>Can't connect to $SESS_DBHOST as $SESS_DBUSER"; 
            echo "<li>MySQL Error: ", mysql_error(); 
            die; 
        } 
     
        if (! mysql_select_db($SESS_DBNAME, $SESS_DBH)) { 
            echo "<li>Unable to select database $SESS_DBNAME"; 
            die; 
        } 
     
        return true; 
    } 
     
    function sess_close() { 
        return true; 
    } 
     
    function sess_read($key) { 
        global $SESS_DBH, $SESS_LIFE; 
        $qry = "SELECT value FROM sessions WHERE sesskey = '$key' AND expiry > " . time(); 
        $qid = mysql_query($qry, $SESS_DBH); 
        if (list($value) = mysql_fetch_row($qid)) return $value; 
        return false; 
    } 
     
    function sess_write($key, $val) { 
        global $SESS_DBH, $SESS_LIFE; 
        $expiry = time() + $SESS_LIFE; 
        $value = addslashes($val); 
        $qry = "UPDATE sessions SET expiry = $expiry, value = '$value' WHERE sesskey = '$key'"; // AND expiry > " . time(); 
        $qid = mysql_query($qry, $SESS_DBH); 
        if(mysql_affected_rows()<1) { 
            $qry = "INSERT INTO sessions (sesskey, expiry, value) VALUES ('$key', $expiry, '$value')"; 
            $qid = mysql_query($qry, $SESS_DBH);        
        } 
        return $qid; 
    } 
     
    function sess_destroy($key) { 
        global $SESS_DBH; 
        $qry = "DELETE FROM sessions WHERE sesskey = '$key'"; 
        $qid = mysql_query($qry, $SESS_DBH); 
        return $qid; 
    } 
     
    function sess_gc($maxlifetime) { 
        global $SESS_DBH; 
        $qry = "DELETE FROM sessions WHERE expiry < " . time(); 
        $qid = mysql_query($qry, $SESS_DBH); 
        return mysql_affected_rows($SESS_DBH); 
    } 
     
    session_set_save_handler( 
        "sess_open", 
        "sess_close", 
        "sess_read", 
        "sess_write", 
        "sess_destroy", 
        "sess_gc");
    merci

  2. #2
    Rédacteur

    Avatar de Yogui
    Homme Profil pro
    Directeur technique
    Inscrit en
    Février 2004
    Messages
    13 721
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yonne (Bourgogne)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Février 2004
    Messages : 13 721
    Par défaut
    Salut

    Essaie avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(sess_destroy($key)){
       header(...);
    }

Discussions similaires

  1. supprimer une session (connection)
    Par sbbn1 dans le forum ASP
    Réponses: 2
    Dernier message: 07/05/2004, 19h57
  2. Réponses: 13
    Dernier message: 16/04/2004, 13h00
  3. [debutant][jsp]Passage d'entier avec une session sans cookie
    Par o151181 dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 04/02/2004, 19h22
  4. Déconnexion d'une session Win2k
    Par lamasse dans le forum C++Builder
    Réponses: 3
    Dernier message: 02/10/2003, 09h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo