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 :

Plus aucun affichage après l'appel d'une méthode de l'API beanutils


Sujet :

Servlets/JSP Java

  1. #1
    Membre habitué

    Développeur informatique
    Inscrit en
    Janvier 2004
    Messages
    149
    Détails du profil
    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2004
    Messages : 149
    Points : 125
    Points
    125
    Par défaut Plus aucun affichage après l'appel d'une méthode de l'API beanutils
    Bonjour à tous,

    J'ai un petit soucis avec la librairie beanutils d'Apache. Quand, dans une servlet, je fais appel à une méthode de cet API, plus rien de ce qui suit n'est pris en compte. Par exemple si je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    out.println("check point 1");
    DynaBean bean = new LazyDynaBean();
    out.println("check point 2");
    je vois check point 1 s'afficher mais pas mon check point 2. Aucune exception n'est levée, aucun message d'erreur n'apparaît nul part...

    J'utilise NetBeans 6.5 et j'ai testé avec les serveurs Tomcat et GlassFish.

    Quelqu'un a-t-il une idée sur le problème ? Si ça tombe c'est un tout petit truc tout simple mais ça m'échappe complètement.

    Merci d'avance !

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    T'as une exception levée, ton conteneur essaie probablement suite à ca d'afficher la page d'erreur, mais c'est impossible étant donnée qu'une partie de la réponse a déjà été envoyée. Le plus simple est d'isoler le bout de code en erreur et de le mettre dans un servlet à part. Ou d'entourer ton code d'un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    try {
    .....
    } catch(Exception e) {
      e.printStackTrace();
      // ou au choix
      // e.printStackTrace(response.getWriter());
    }

  3. #3
    Membre habitué

    Développeur informatique
    Inscrit en
    Janvier 2004
    Messages
    149
    Détails du profil
    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2004
    Messages : 149
    Points : 125
    Points
    125
    Par défaut
    Hélas non ça n'est pas ça, comme je l'ai dit aucune exception n'est levée, c'est ça le plus troublant. En revanche dans un moment de clairvoyance j'ai tenté de capter une erreur (Error) au lieu d'une exception... et là, jackpot ! Enfin façon de parler car je suis un peu perdu quand même, mais au moins j'ai localisé le problème.
    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
    java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
    	at org.apache.commons.beanutils.LazyDynaBean.<init>(LazyDynaBean.java:119)
    	at org.apache.commons.beanutils.LazyDynaBean.<init>(LazyDynaBean.java:162)
    	at servlets.MyServlet.processRequest(MyServlet.java:36)
    	at servlets.MyServlet.doGet(MyServlet.java:58)
    	at javax.servlet.http.HttpServlet.service(HttpServlet.java:734)
    	at javax.servlet.http.HttpServlet.service(HttpServlet.java:847)
    	at org.apache.catalina.core.ApplicationFilterChain.servletService(ApplicationFilterChain.java:427)
    	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:315)
    	at org.apache.catalina.core.StandardContextValve.invokeInternal(StandardContextValve.java:287)
    	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:218)
    	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:648)
    	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:593)
    	at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:94)
    	at com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:98)
    	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:222)
    	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:648)
    	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:593)
    	at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:587)
    	at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:1096)
    	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:166)
    	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:648)
    	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:593)
    	at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:587)
    	at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:1096)
    	at org.apache.coyote.tomcat5.CoyoteAdapter.service(CoyoteAdapter.java:288)
    	at com.sun.enterprise.web.connector.grizzly.DefaultProcessorTask.invokeAdapter(DefaultProcessorTask.java:647)
    	at com.sun.enterprise.web.connector.grizzly.DefaultProcessorTask.doProcess(DefaultProcessorTask.java:579)
    	at com.sun.enterprise.web.connector.grizzly.DefaultProcessorTask.process(DefaultProcessorTask.java:831)
    	at com.sun.enterprise.web.connector.grizzly.DefaultReadTask.executeProcessorTask(DefaultReadTask.java:341)
    	at com.sun.enterprise.web.connector.grizzly.DefaultReadTask.doTask(DefaultReadTask.java:263)
    	at com.sun.enterprise.web.connector.grizzly.DefaultReadTask.doTask(DefaultReadTask.java:214)
    	at com.sun.enterprise.web.connector.grizzly.TaskBase.run(TaskBase.java:265)
    	at com.sun.enterprise.web.connector.grizzly.ssl.SSLWorkerThread.run(SSLWorkerThread.java:106)
    Caused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
    	at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
    	at java.security.AccessController.doPrivileged(Native Method)
    	at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
    	at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1014)
    	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1567)
    	at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
    	... 33 more
    Donc d'après ce que je comprends, quelque soit la classe de l'API beanutils que j'essaie d'utiliser, lors de l'exécution elle demeure introuvable... le mystère est pour moi encore complet. Enfin j'avance... une idée ?

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
    T'as oublié de mettre les classes de commons logging dans ton application. (Beanutils dépend de commons logging)

  5. #5
    Membre habitué

    Développeur informatique
    Inscrit en
    Janvier 2004
    Messages
    149
    Détails du profil
    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2004
    Messages : 149
    Points : 125
    Points
    125
    Par défaut
    Effectivement c'était bien ça. Merci beaucoup pour ton aide !

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

Discussions similaires

  1. Problème d'affichage lors d'appelle d'une méthode
    Par FATENMRABET dans le forum Débuter avec Java
    Réponses: 4
    Dernier message: 03/12/2013, 23h12
  2. [delphi 4] erreur d'affichage apres l'ouverture d'une fiche 2 fois
    Par manu7901 dans le forum Bases de données
    Réponses: 1
    Dernier message: 16/01/2007, 17h32
  3. Appel d'une méthode d'après son nom
    Par RemiRoques dans le forum API standards et tierces
    Réponses: 3
    Dernier message: 19/06/2006, 13h14
  4. Problème de retour aprés l'appel d'une popup
    Par PADAWANN33 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 06/02/2006, 15h53
  5. Réponses: 5
    Dernier message: 29/07/2005, 09h00

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