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

Servlets/JSP Java Discussion :

Problème destruction Session


Sujet :

Servlets/JSP Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2012
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 60
    Par défaut Problème destruction Session
    Bonjour à tous,

    Dans mon site je dois identifier un utilisateur pour qu'il puisse accéder à certaines partie du site.
    J'ai déjà coder la partie identification. Et la partie déconnexion.
    Une fois l'utilisateur identifié on créer une session. Puis une variable de session (statusconnect) qui est à true.

    Création de la session :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session=request.setAttribute("session",true);
    Dans la partie déconnexion comme ligne de code j'ai mis :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    session.removeAttribute("statusconnect");
    session.invalidate();
    response.SendRedirect("login.jsp");
    Une fois déconnecté, lorsque que je tape l'adresse d'une page sécurisé je peux toujours y accéder. Au début du fonctionnement j'ai une condition qui vérifie l'existence d'une session :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(session==null) response.sendRedirect("login.jsp");
    Sinon en paramètre servlet j'ai :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <%@ page import="java.sql.*,java.util.*"%>
    Là je suis un peu perdu, je crois peut être qu'il manque un librairie dans l'import ?
    Soit la l'objet n'existe pas (la syntaxe est fausse) ?
    Où soit la destruction de la session n'a pas lieu ?
    Où encore il y a un problème de cache ?
    Soit la base le conteneur de servlet qui n'est pas configuré ?
    Il ne faudrait pas installer une librairie particulière ?

    Merci d'avance.

  2. #2
    Membre éclairé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2012
    Messages : 49
    Par défaut
    Bonjour,
    Tu pourrais essayer d'ajouter

    juste après le session.invalidate();

    Enfin je ne sais pas exactement si cela reglera ton problème !

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2012
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 60
    Par défaut
    Salut Couci,

    Je viens d'essayer ton morceau de code est le résultat est toujours le même.
    Merci quand même.

  4. #4
    Membre expérimenté
    Avatar de karbos
    Inscrit en
    Novembre 2008
    Messages
    155
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 155
    Par défaut
    Citation Envoyé par Burton's91 Voir le message
    Création de la session :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session=request.setAttribute("session",true);
    Dans la partie déconnexion comme ligne de code j'ai mis :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    session.removeAttribute("statusconnect");
    session.invalidate();
    response.SendRedirect("login.jsp");
    Une fois déconnecté, lorsque que je tape l'adresse d'une page sécurisé je peux toujours y accéder. Au début du fonctionnement j'ai une condition qui vérifie l'existence d'une session :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(session==null) response.sendRedirect("login.jsp");
    Je pense que les cas où tu rentreras dans ton
    sont très rare...
    Je crois que tu voulais plutôt écrire
    1) dans la partie connexion :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session=session.setAttribute("statusconnect",true);
    2) dans la partie déconnexion :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    session.setAttribute("statusconnect", false); //ou session.removeAttribute("statusconnect");
    response.SendRedirect("login.jsp");
    3) et le test devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(session.getAttribute("statusconnect") == null || session.getAttribute("statusconnect").equals(false)){
      response.SendRedirect("login.jsp");
    }
    Pas très secure, mais ça devrait mieux marcher

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2012
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 60
    Par défaut
    çà à l'air de marcher. Mais niveau sécurité c'est pas le top.
    Cette solution est une alternative car pour l'instant l'utilisation de la classe javax.servlet.http.HttpServletRequest. Pose problème. Je sais pas s'il faut rajouter un fichier.jar où s'il est déjà installer.

    Sinon
    Merci karbos

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

Discussions similaires

  1. [Servlets - JSP] Problème de session
    Par the java lover dans le forum Servlets/JSP
    Réponses: 8
    Dernier message: 28/11/2011, 09h54
  2. Problème de session
    Par meda dans le forum Langage
    Réponses: 13
    Dernier message: 25/10/2005, 18h25
  3. problème de session en cours
    Par bertrand_declerck dans le forum Bases de données
    Réponses: 2
    Dernier message: 19/07/2005, 14h36
  4. Réponses: 14
    Dernier message: 02/03/2005, 18h15
  5. Gros problème de session/cookies
    Par valfredr dans le forum XMLRAD
    Réponses: 18
    Dernier message: 03/06/2004, 09h21

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