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

JDBC Java Discussion :

Boucle infini avec exploitation d'un resultset


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Inscrit en
    Avril 2007
    Messages
    219
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 219
    Points : 66
    Points
    66
    Par défaut Boucle infini avec exploitation d'un resultset
    Bonjour, j'ai une classe chargée de l'identification d'utilisateurs via une base de données mysql. Si les identifiants sont bons, pas de problème. En revanche, lorsque que les identifiants ne correspondent pas avec ceux de la base, mon code tourne en boucle infinie. Je suis sûr qu'il s'agit d'une erreur bête mais je débute. Pourriez vous m'aider svp?

    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
    try {
                Database db = new Database("app");
                Connection connexion = db.getConnexion();
                Statement query = connexion.createStatement();
                if(query.execute("SELECT id FROM stagiaire WHERE nom = '"+nom+"' AND prenom = '"+prenom+"' AND motdepasse = '"+pwd+"'")) {
                    ResultSet datas = query.getResultSet();
                    if(datas != null) {
                        while(datas.next()) {
                            stagiaire = new Stagiaire(datas.getInt(1));
                        }
                        datas.close();
                    }
                    query.close();
                }
                connexion.close();
            }
     
            catch (Exception e) {
                e.printStackTrace();
            }

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    Bonjour,

    je pense que tu devrais plutot faire comme suis !

    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
     
    		Statement query = null;
    		ResultSet datas = null;
    		Database db = new Database("app");
    		Connection connexion = db.getConnexion();
    		try {
    			query = connexion.createStatement();
    			datas = query.executeQuery("SELECT id FROM stagiaire WHERE nom = '" + nom + "' AND prenom = '" + prenom + "' AND motdepasse = '" + pwd + "'");
    			while (datas.next()) {
    				stagiaire = new Stagiaire(datas.getInt(1));
    			}
     
    		} catch (Exception e) {
    			e.printStackTrace();
    		} finally {
    			try {
    				if (datas != null) {
    					datas.close();
    				}
    			} catch (Exception e) {
    				// rien a faire
    			}
    			try {
    				if (query != null) {
    					query.close();
    				}
    			} catch (Exception e) {
    				// rien a faire
    			}
    			try {
    				if (connexion != null) {
    					connexion.close();
    				}
    			} catch (Exception e) {
    				// rien a faire
    			}
    		}
    D'autre part, dans ton code en cas d'erreur tu ne fermais ni le resultSet, ni le statement, ni la connexion.
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre du Club
    Inscrit en
    Avril 2007
    Messages
    219
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 219
    Points : 66
    Points
    66
    Par défaut
    J'ai essayé ta solution sans succès. JBoss me génère toujours des erreurs en boucle tout en pédalant... Un petit aperçu:

    13:47:31,250 ERROR [[jsp]] "Servlet.service()" pour la servlet jsp a généré une exception
    java.lang.NoClassDefFoundError: javax/servlet/jsp/SkipPageException
    at org.apache.jsp.login_jsp._jspService(login_jsp.java:152)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:373)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:336)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:265)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
    at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:179)
    at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:84)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:157)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:262)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:446)
    at java.lang.Thread.run(Thread.java:619)

  4. #4
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    ton problème ne vient pas du code que tu as mis !!!
    Il vient du fait que la classe javax/servlet/jsp/SkipPageException n'a pas été trouvé il te manque surement des jars dans le path.
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre du Club
    Inscrit en
    Avril 2007
    Messages
    219
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 219
    Points : 66
    Points
    66
    Par défaut
    En effet! Le package javax.servlet.jsp est vide! Pourtant tout doit être inclus avec JBoss, non? Et pourquoi dans ce cas je peux tout de même exécuter des jsp? Comment remédier à cela?

  6. #6
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    Je ne sais pas car je n'ai pas de compétence sur jboss !! eventuellement fait un post sur le forum qui va bien !
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

Discussions similaires

  1. arrêter une boucle infinie avec DoEvents
    Par 3aychoucha dans le forum C++/CLI
    Réponses: 5
    Dernier message: 31/03/2011, 21h48
  2. [Débutant] Boucle infini avec while
    Par Romm1 dans le forum Interfaces Graphiques
    Réponses: 7
    Dernier message: 23/03/2011, 11h38
  3. [Exchange 2003] Boucle infinie avec l'autoreply
    Par fredpte dans le forum Exchange Server
    Réponses: 0
    Dernier message: 05/05/2010, 13h10
  4. paint() en boucle infinie avec JDesktopPane
    Par Spidy dans le forum Débuter
    Réponses: 6
    Dernier message: 19/03/2009, 16h31
  5. [JMeter] Problème avec la boucle infinie pour les tests
    Par zegreg dans le forum Tests et Performance
    Réponses: 1
    Dernier message: 05/10/2005, 11h41

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