|
Publicité ' | ||||||||||||||||||||||
|
|
#1 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Bonjour,
J'ai une application dont le point d'entrée est une servlet. Dans cette servlet je met un attribut "user" en session. Ensuite, je redirige l'utilisateur vers une JSP. Dans cette JSP j'ai un appel Ajax vers une autre servlet. Lorsque une exception non catchée se produit côté serveur (erreur 500) à l'appel de cette servlet, l'attribut user de ma session devient null. Avez-vous une idée pourquoi ? J'avoue ne pas trop voir le rapport, est-ce que le fait d'avoir une exception non catchée flush la session ? Merci d'avance Dany
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#2 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Faudrait nous donner un peu de code je pense.
Est ce que tu as accès aux autres éléments de ta sessions ? C'est bien la même session ?
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
|
|
#3 | ||||||
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Voici un peu de détails :
Servlet 1 (point d'entrée de l'application) : Code :
Servlet 2 (appelée par une requête Ajax) : Code :
Code :
EDIT : pour répondre à ta question thierryler, je n'ai pas accès aux autres éléments de ma session non plus.
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
||||||
|
|
00
|
|
|
#4 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Ah ah... après avoir investigué, lorsque je passe dans ma "Servlet 3", l'id de session a changé ! Il est donc logique que je ne retrouve pas mes attributs.
Mais alors ma question est la suivante : pourquoi est-ce que ma première session est invalidée après mon exception ?
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#5 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Ma question était orientée, comme tu as du le deviner.
Deux pistes : 1) toutes tes appels vont vers des sessions différentes ; 2) ou alors tes appels standards et ajax ont deux sessions différentes.
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
|
|
#6 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Je pense devoir écarter tes pistes car lorsque je n'ai pas d'exception, l'id de session ne change pas et mes attributs sont toujours dans la session.
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#7 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Fais voir la trace avec ton exception. On va peut être découvrir un truc dedans. A mon avis ça doit être tout con.
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
|
|
#8 | ||
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Voici la trace, j'ai remplacé mes noms de package par --------------, simple précaution de confidentialité :
Code :
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
||
|
|
00
|
|
|
#9 | ||
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Tu peux mettre ça dans ta servlet 2 avant le cast qui fait planter :
Code :
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
||
|
00
|
|
|
#10 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Dans tous les cas, j'aurais tendance à dire que tu devrais avoir un try catch autour de ton cast de Long, comme ça a l'air d'être fonctionnel. Du coup ça résoudrait aussi ton affaire.
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
|
|
#11 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
J'avais déjà fais le test, à ce moment là l'utilisateur est bien présent dans la session.
C'est vraiment l'exception qui provoque le problème
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#12 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Nan mais tu te doutes bien que pour l'exemple je force une exception pourrie mais ma servlet appel des services qui peuvent potentiellement générer des exceptions techniques de toute sorte.
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#13 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Oui mais si tu ne gères pas l'exception au niveau du doPost, tu vas la laisser se propager ?
Attend, je fais le point dans mon esprit. Ta servlet 1 met le user en session. Ta servlet 2, appelée en ajax depuis la JSP, fait l'exception. Du coup l'appel Ajax se fini en erreur. Quand tu vas dans servlet 3, le user a disparu, mais ça reste le même id de session ? Ca fait longtemps que j'ai pas fais de servlet pure... A tout hasard, ton exception n'a pas flingué ta session ? Je veux dire, toute la session, pas juste tes params. Dans tous les cas, je persiste, ta servlet 2 devrait gérer l'exception.
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
|
|
#14 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Alors, mon exception flingue ma session, pas juste les attributs, car l'id de session a changé quand j'appelle la Servlet 3.
Ensuite, au niveau de ta remarque sur le fait de gérer l'exception, ça veut dire que je suis obligé de faire un vieux try catch de java.lang.Exception pour être sûr de pas pommer ma session... Pas sûr que ce soit une bonne pratique. Moi je catch les exceptions que je connais (que j'ai identifié) et pour le reste, la trace renseigne sur l'exception et l'utilisateur est simplement averti d'une erreur 500. Après si tu me dis qu'une exception non catchée dans une servlet provoque la mort de la session, ok. Mais en faisant des recherches sur Google, j'ai n'ai rien trouvé en ce sens. C'est pour ça, ça me parait bizarre ce problème...
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#15 | ||||
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
Ah la la j'ai trouvé ! Vicieux...
Voici un extrait de mon web.xml : Code :
Et voici une partie du code de erreur500.jsp : Code :
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
||||
|
|
00
|
|
|
#16 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Effectivement...
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
|
|
#17 |
|
Membre confirmé
![]() Dany Développeur Java Inscription : décembre 2005 Messages : 527 ![]() |
En tout cas merci de ton aide
__________________
"Wash me away Clean your body of me Erase all the memories They'll only bring us pain And I've seen All i'll ever need" |
|
|
00
|
|
|
#18 |
![]() ![]() Thierry Leriche-DessirierInscription : octobre 2007 Messages : 2 137 ![]() |
Je t'en prie. Au moins ça a mis sur la bonne piste.
__________________
Thierry Leriche-Dessirier Ingénieur Architecte JEE Freelance Rédacteur pour Developpez Professeur de Génie Logiciel à l'ESIEA Page sur Developpez : http://thierry-leriche-dessirier.developpez.com Site : http://www.icauda.com Linked'in : http://www.linkedin.com/in/thierryler Twitter : http://www.twitter.com/thierryleriche |
|
00
|
Copyright © 2000-2013 - www.developpez.com