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

Java EE Discussion :

problème affichage des données mysql dans la vue


Sujet :

Java EE

  1. #1
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 17
    Points : 14
    Points
    14
    Par défaut problème affichage des données mysql dans la vue
    Bonjour Tout le monde , je débute en jEE , et je suis bloquée dans le problèmes d'affichages des données mysql


    Je vous prie de bien vouloir m'aider ça fait presque deux jours que je chercher sur l'internet mais en vain , ça me tape sur les nerfs

    voici le code de mon jsp
    Code jsp : 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
    <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8" />
    <title>Tests JDBC</title>
    <link type="text/css" rel="stylesheet" href="<c:url
    value="/inc/form.css"/>" />
    </head>
    <body>
    <h1>Tests JDBC</h1>
     
        <form method="post" action= "test_jdbc">
            <p>
                <label for="nom"> Nom : </label>
                <input type="text" name="nom" id="nom" />
                </p>
     
                <p>
                <label for="email"> Email : </label>
                <input type="text" name="email" id="email" />
                </p>
     
        <input type="submit" />
        </form>
     
     
    <ul>
        <c:forEach var="Utilisateur" items="${utilisateurs } ">
            <li>
             <c:out value="${Utilisateur.nom }" />
             <c:out value="${Utilisateur.email }" />
             </li>
        </c:forEach>
    </ul>
     
     
    </body>
    </html>

    celui de ma servlet
    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
    package com.sdzee.servlets;
    import java.io.IOException;
    import java.util.List;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import com.sdzee.bdd.TestJDBC;
    import com.sdzee.beans.Utilisateur;
     
     
     
    public class GestionTestJDBC extends HttpServlet {
     
     
    public static final String ATT_MESSAGES = "utilisateurs";
    public static final String VUE = "/WEBINF/test_jdbc.jsp";
     
    public void doGet( HttpServletRequest request, HttpServletResponse response ) throws ServletException, IOException
    {
        TestJDBC tableNoms = new TestJDBC();
        request.setAttribute("utilisateurs" , tableNoms.recupererUtilsateurs());
        this.getServletContext().getRequestDispatcher("/web-INF/test_jdbc.jsp").forward(request, response);
     
    }
     
    public void doPost ( HttpServletRequest request , HttpServletResponse response ) throws ServletException , IOException {
        Utilisateur utilisateur = new Utilisateur() ;
        utilisateur.setNom(request.getParameter("nom"));
        utilisateur.setEmail(request.getParameter("email"));
     
        TestJDBC tableNoms = new TestJDBC();
        tableNoms.ajouterUtilisateur(utilisateur);
        request.setAttribute("utilisateurs" , tableNoms.recupererUtilsateurs());
     
        this.getServletContext().getRequestDispatcher("/web-INF/test_jdbc.jsp").forward(request, response);
    }
    }

    ma classe JAVA

    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
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    package com.sdzee.bdd;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.ArrayList;
    import java.util.List;
    import javax.servlet.http.HttpServletRequest;
     
    import com.sdzee.beans.Utilisateur;
    public class TestJDBC {
        public List<Utilisateur> recupererUtilsateurs() {
            List<Utilisateur> utilisateurs = new ArrayList<Utilisateur>();
            try {
                Class.forName( "com.mysql.jdbc.Driver" );
            } catch ( ClassNotFoundException e ) {
            }
            try {
                Class.forName( "com.mysql.jdbc.Driver" );
            } catch ( ClassNotFoundException e ) {
            }
            Connection connexion = null;
            Statement statement = null;
            ResultSet resultat = null;
     
            loadDatabase();
     
            try {
                connexion = DriverManager.getConnection( "jdbc:mysql://localhost:3306/flotte_mobile", "root", "**********" );
                statement = connexion.createStatement();
                resultat = statement.executeQuery( "SELECT nom , email FROM user ;" );
                while ( resultat.next() ) {
     
                    String email = resultat.getString( "email" );
                    String nom = resultat.getString("motdepasse" );
                    String motdepasse = resultat.getString( "nom" );
     
                    Utilisateur utilisateur = new Utilisateur() ;
     
                    utilisateur.setNom("nom");
                    utilisateur.setEmail("Email");
                    utilisateurs.add(utilisateur);
                }
            } catch ( SQLException e ) {
            } finally {
                try {
                    if ( resultat != null )
                        resultat.close();
                    if ( statement != null )
                        statement.close();
                    if ( connexion != null )
                        connexion.close();
                }catch ( SQLException ignore) {
                }
            }
            return utilisateurs;
        }
     
        private void loadDatabase() {
            try {
                Class.forName("com.mysql.jdbc.Driver");
     
            }catch ( ClassNotFoundException e) {
     
            }
            Connection connexion = null;
            try {
                connexion = DriverManager.getConnection("jdbc:mysql://localhost:3306/flotte_mobile", "root", "*******");
            }catch(SQLException e ) {
                e.printStackTrace();
            }
     
        }
     
     
        public void ajouterUtilisateur(Utilisateur utilisateur) {
            loadDatabase() ;
            Connection connexion = null;
            try {
                PreparedStatement preparedStatement = connexion.prepareStatement("INSERT INTO user ( email ,nom ) VALUES (? , ? );");
                preparedStatement.setString(1, utilisateur.getEmail());
                preparedStatement.setString(2, utilisateur.getNom());
                preparedStatement.executeUpdate() ;
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
     
        }
    }
    l'erreur lors de l'exécution

    description Le serveur a rencontré une erreur interne qui l''a empêché de satisfaire la requête.

    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
    exception
     
    org.apache.jasper.JasperException: An exception occurred processing JSP page /test_jdbc.jsp at line 31
     
    28: <ul>
    29:     <c:forEach var="Utilisateur" items="${utilisateurs } ">
    30:         <li>
    31:          <c:out value="${Utilisateur.nom  }" />
    32:          <c:out value="${Utilisateur.email  }" />  
    33:          </li>
    34:     </c:forEach>
     
     
    Stacktrace:
        org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:613)
        org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:510)
        org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395)
        org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339)
        javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
        org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    cause mère
     
    javax.el.PropertyNotFoundException: Property 'nom' not found on type java.lang.String
        javax.el.BeanELResolver$BeanProperties.get(BeanELResolver.java:291)
        javax.el.BeanELResolver$BeanProperties.access$300(BeanELResolver.java:243)
        javax.el.BeanELResolver.property(BeanELResolver.java:378)
        javax.el.BeanELResolver.getValue(BeanELResolver.java:97)
        org.apache.jasper.el.JasperELResolver.getValue(JasperELResolver.java:104)
        org.apache.el.parser.AstValue.getValue(AstValue.java:184)
        org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:190)
        org.apache.jasper.runtime.PageContextImpl.proprietaryEvaluate(PageContextImpl.java:950)
        org.apache.jsp.test_005fjdbc_jsp._jspx_meth_c_005fout_005f0(test_005fjdbc_jsp.java:244)
        org.apache.jsp.test_005fjdbc_jsp._jspx_meth_c_005fforEach_005f0(test_005fjdbc_jsp.java:201)
        org.apache.jsp.test_005fjdbc_jsp._jspService(test_005fjdbc_jsp.java:123)
        org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
        javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
        org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:472)
        org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395)
        org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339)
        javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
        org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    note La trace complète de la cause mère de cette erreur est disponible dans les fichiers journaux de ce serveur.

  2. #2
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 310
    Points : 9 522
    Points
    9 522
    Billets dans le blog
    1
    Par défaut
    D'après le message d'erreur, il semble que ta variable Utilisateur représente un String, pas un objet Utilisateur.
    Peux-tu faire le test en remplaçant ${Utilisateur.nom} par ${Utilisateur} et mettre la ligne suivante en commentaire (<c:out value="${Utilisateur.email  }" />)
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 17
    Points : 14
    Points
    14
    Par défaut
    Citation Envoyé par OButterlin Voir le message
    D'après le message d'erreur, il semble que ta variable Utilisateur représente un String, pas un objet Utilisateur.
    Peux-tu faire le test en remplaçant ${Utilisateur.nom} par ${Utilisateur} et mettre la ligne suivante en commentaire (<c:out value="${Utilisateur.email  }" />)
    Mercii d'abord pour votre retour , j'ai fait ce que tu m'as demandé et il me semble que le problème est au niveau de mon Arrraylist
    voici l"execution que j'obtiens
    Nom : Capture.PNG
Affichages : 298
Taille : 10,9 Ko

  4. #4
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                    utilisateur.setNom("nom");
                    utilisateur.setEmail("Email");
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                    utilisateur.setNom(nom);
                    utilisateur.setEmail(email);
    Quelle version de Mysql Connector tu utilises? Parce que la version 8 utilise com.mysql.cj.jdbc.Driver, et le chargement du driver n'est plus utile depuis JDBC 4.
    Il faut aussi afficher aussi les erreurs dans le catch.

    Code jsp : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <c:forEach var="Utilisateur" items="${utilisateurs } ">
            <li>
             <c:out value="${Utilisateur.nom }" />
             <c:out value="${Utilisateur.email }" />
             </li>
        </c:forEach>
    Par convention, le nom d'une variable doit commencer par un minuscule.

    A+.

  5. #5
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 310
    Points : 9 522
    Points
    9 522
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par CarolineSamaha Voir le message
    Mercii d'abord pour votre retour , j'ai fait ce que tu m'as demandé et il me semble que le problème est au niveau de mon Arrraylist
    voici l"execution que j'obtiens
    Nom : Capture.PNG
Affichages : 298
Taille : 10,9 Ko
    Il semble bien que le problème vienne de ta variable, comme s'il trouvait une autre variable que celle de la servlet.
    Ce que tu peux tester c'est de préciser le scope de la variable, comme ceci
    Code jsp : Sélectionner tout - Visualiser dans une fenêtre à part
    <c:forEach items="${requestScope.utilisateurs}"...>
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  6. #6
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 17
    Points : 14
    Points
    14
    Par défaut
    Citation Envoyé par OButterlin Voir le message
    Il semble bien que le problème vienne de ta variable, comme s'il trouvait une autre variable que celle de la servlet.
    Ce que tu peux tester c'est de préciser le scope de la variable, comme ceci
    Code jsp : Sélectionner tout - Visualiser dans une fenêtre à part
    <c:forEach items="${requestScope.utilisateurs}"...>


    Je l'ai changé mais ça reste le même prob , mes données ne s'affichent pas

  7. #7
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 17
    Points : 14
    Points
    14
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Bonjour,



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                    utilisateur.setNom(nom);
                    utilisateur.setEmail(email);
    Quelle version de Mysql Connector tu utilises? Parce que la version 8 utilise com.mysql.cj.jdbc.Driver, et le chargement du driver n'est plus utile depuis JDBC 4.
    Il faut aussi afficher aussi les erreurs dans le catch.



    Par convention, le nom d'une variable doit commencer par un minuscule.

    A+.
    j'utilise mysql connector 8.0.14
    j ai fait les changement mais ça m'affiche les même erreur , je suis vraiment bloquée :/

  8. #8
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Commence par virer les codes inutiles
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    try {
                Class.forName( "com.mysql.jdbc.Driver" );
            } catch ( ClassNotFoundException e ) {
            }
            try {
                Class.forName( "com.mysql.jdbc.Driver" );
            } catch ( ClassNotFoundException e ) {
            }
    Affiche ensuite les stack trace dans les catch.
    Tu n'as récupéré que nom et email dans ta requête mais pas motdepasse. Tu dois avoir un SQLException mais tu l’aperçois pas parce que tu n'affiches pas les erreurs dans ton catch.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    resultat = statement.executeQuery( "SELECT nom , email FROM user ;" );
                while ( resultat.next() ) {
     
                    String email = resultat.getString( "email" );
                    String nom = resultat.getString("motdepasse" ); // Exception ici
                    String motdepasse = resultat.getString( "nom" );
    A+.

Discussions similaires

  1. [MySQL] Affichage par php des données mysql dans un tableau html
    Par JDP91 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 17/05/2015, 09h10
  2. Affichage de données MySQL dans une vue
    Par mymemorial dans le forum Zend_Db
    Réponses: 6
    Dernier message: 24/04/2013, 15h02
  3. Insérer des données MySQL dans Oracle
    Par plou_fr dans le forum Bases de données
    Réponses: 7
    Dernier message: 02/02/2008, 15h25
  4. [MySQL] Problème Affichage des données
    Par buzzchewan dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 15/02/2007, 15h05
  5. Réponses: 3
    Dernier message: 04/01/2007, 17h42

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