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

ASP.NET Discussion :

Redirection après l'expiration de session


Sujet :

ASP.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de paradeofphp
    Inscrit en
    Décembre 2005
    Messages
    313
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 313
    Par défaut Redirection après l'expiration de session
    Bonjour,
    Ma question est simple. Je veux après l'expiration de session, redireger l'utilisateur vers une page indiquant que la session a expiré. Pour ce faire, j'ai rajouté le code suivant au chargement de la page conteneur :

    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
                If Not Context.Session Is Nothing Then
     
                    'Tested and the IsNewSession is more advanced then simply checking if 
                    ' a cookie is present, it does take into account a session timeout, because 
                    ' I tested a timeout and it did show as a new session
                    If Session.IsNewSession Then
                        ' If it says it is a new session, but an existing cookie exists, then it must 
                        ' have timed out (can't use the cookie collection because even on first 
                        ' request it already contains the cookie (request and response
                        ' seem to share the collection)
                        Dim szCookieHeader As String = Request.Headers("Cookie")
                        If (Not szCookieHeader Is Nothing) And (szCookieHeader.IndexOf("ASP.NET_SessionId") >= 0) Then
     
                            Response.Redirect("sessionTimeout.htm")
                        End If
                    End If
                End If
    Après l'expiration de session, j'ai la procedure session_end du Global.asax qui s'execute automatiquement. Dans cette procédure, je ferme la connexion à la base de données.

    Mon problème est que lorsque je clique sur un lien du projet après que la session ait expiré, j'ai une exception qui est levée. Donc, le bout de code ( en haut) ne s'execute pas.

    COmment je peux faire alors pour effectuer la redirection ? Merci

  2. #2
    Membre éclairé Avatar de paradeofphp
    Inscrit en
    Décembre 2005
    Messages
    313
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 313
    Par défaut
    C bon, c'est résolu

    Alors la solution consiste à rajouter une balise Meta d'information.
    Cette balise c'est Refresh. Elle oblige le navigateur à rafraîchir la page au bout d'un temps donné (en seconde). Après rafraichessement, je teste si la session a expiré, si c'est le cas, je fais la redirection.

    Je l'ai rajouté au niveau du code. Vous pouvez la mettre directement dans le code HTML. Voici la solution :


    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
    Response.AddHeader("Refresh", Convert.ToString((Session.Timeout * 60) + 5))
     
                If Not Context.Session Is Nothing Then
     
                    'Tested and the IsNewSession is more advanced then simply checking if 
                    ' a cookie is present, it does take into account a session timeout, because 
                    ' I tested a timeout and it did show as a new session
                    If Session.IsNewSession Then
                        ' If it says it is a new session, but an existing cookie exists, then it must 
                        ' have timed out (can't use the cookie collection because even on first 
                        ' request it already contains the cookie (request and response
                        ' seem to share the collection)
                        Dim szCookieHeader As String = Request.Headers("Cookie")
                        If (Not szCookieHeader Is Nothing) And (szCookieHeader.IndexOf("ASP.NET_SessionId") >= 0) Then
                            ' Log User Off from Cookie Authentication System
                            FormsAuthentication.SignOut()
                            ' Invalidate roles token
                            Response.Cookies("portalroles").Value = Nothing
                            Response.Cookies("portalroles").Path = "/"
                            Response.Cookies("portalroles").Expires = New System.DateTime(1999, 10, 12)
                            ' Redirecton vers la page 
                            Response.Redirect("~/Admin/AccessDenied.aspx")
                        End If
                    End If
                End If

    Voila, j'espère que cette solution va vous aider. A bientot

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [2.x] Redirection après un login précédé d'un session timeout
    Par placide90 dans le forum Symfony
    Réponses: 1
    Dernier message: 21/05/2015, 12h06
  2. Redirection après ouverture de session
    Par Général03 dans le forum Langage
    Réponses: 9
    Dernier message: 02/12/2009, 21h35
  3. Redirection après expiration d'un bean session?
    Par toutoune60 dans le forum JSF
    Réponses: 4
    Dernier message: 26/02/2007, 18h17
  4. probleme de redirection a expiration de session
    Par zorba49 dans le forum ASP
    Réponses: 5
    Dernier message: 30/03/2006, 11h37
  5. Probleme de redirection apres fermeture de session
    Par soufienne dans le forum ASP
    Réponses: 3
    Dernier message: 08/04/2004, 10h52

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