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 :

Je ne trouve pas l'erreur dans la page JSP


Sujet :

Servlets/JSP Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut Je ne trouve pas l'erreur dans la page JSP
    est ce que quelqu'un a une idée sur la faute que j'ai commis en voulant faire une update a mon tableau sachant que je croit que l'erreur est dans la date avec une probabilité de 80%

    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
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    <%@page import="java.sql.*"%>
    <%@page import="java.lang.*"%>
    <%@ page import="java.util.*"%>
    <%@ page import="java.text.*"%>
    <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
        pageEncoding="ISO-8859-1"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
    <title>ModifierUtilisateur</title>
     <link rel="stylesheet" href="style.css" type="text/css" />
    </head>
    <body>
    //fonction pour changer la forme de la date
     
    <%!
    public static java.sql.Date testParseDate (String dateString)
    {
        java.sql.Date sDate = null;
     
        try 
        {
            SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
            // Conversion de la valeur String en java.util.Date via SimpleDateFormat
            java.util.Date uDate = sdf.parse(dateString);
            // puis conversion de java.util.Date en java.sql.Date (ce qui est requis pour JDBC)
            sDate = new java.sql.Date(uDate.getTime());
        } 
        catch(Exception e) 
        {
            System.err.println("Exception :");
            e.printStackTrace();
        }
        return sDate;
    } 
    %>
     
     
    <%
    String eche="";
    String nom="";
    String codeiso="";
    String nomdecimal="";
    String decimal="";
    String IADEmpl="";
    Connection connection=null;
    Statement statement;
    ResultSet rs ;
     
     
    String tab[]=new String[5];
    tab=request.getQueryString().split("/");
     
    //pour afficher le contenu des variable est c'est encore fonctionnel
    IADEmpl= tab[0];
    System.out.println("IADEmpl1="+IADEmpl);
    if(tab.length>1){
            System.out.println("ssssssss="+IADEmpl);
        request.getSession().setAttribute("Ncompte",IADEmpl);
            
            try{
                    Class.forName("com.mysql.jdbc.Driver");
            }catch(Exception e){
                    e.printStackTrace();
            }
            try{
                    connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/banque","root","");
            }catch(Exception e){
                    e.printStackTrace();
            }
            
            String sql="SELECT * FROM utilisateur where Ncompte='"+IADEmpl+"'" ;
            try {
                    statement=connection.createStatement();
                    rs = statement.executeQuery(sql);
                     if(rs.next()){
                    //maDate = testParseDate(request.getParameter("echeance"));
                    eche=rs.getString("echeance");
                    nom=rs.getString("Ncompte");
                    codeiso=rs.getString("nompre");
                    nomdecimal=rs.getString("banque");
                    decimal=rs.getString("moypay");
                    
                     }
                    
             } 
            catch (SQLException e) 
             {
                    e.printStackTrace();
             }         
            finally
            {
                    try
                    {
                            connection.close();     
                    }
                    catch (Exception e)
                    {
                            e.printStackTrace();
                    }
            }
    }
    //a partir de  cette partie je ne sais plus où est mon erreur
     
    else{
            IADEmpl = (String)request.getSession().getAttribute("Ncompte");
            System.out.println("IADEmpl="+IADEmpl);
            
            eche = request.getParameter("echeance");
            java.sql.Date maDate = testParseDate(request.getParameter("eche"));
            
            nom = request.getParameter("nom");
            System.out.println("nom="+nom);
            
            codeiso = request.getParameter("codeiso");
            nomdecimal = request.getParameter("nomdecimal");
            
            decimal = request.getParameter("decimal");
            try{
                    Class.forName("com.mysql.jdbc.Driver");
            }catch(Exception e){
                    e.printStackTrace();
            }
            try{
                    connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/banque","root","");
            }catch(Exception e){
                    e.printStackTrace();
            }
            
            PreparedStatement pstmt = connection.prepareStatement("update utilisateur (echeance,Ncompte,nompre,banque,moypay)VALUES (?,?,?,?,?)WHERE Ncompte= '"+IADEmpl+"'");
        pstmt.setDate(1,maDate);
        pstmt.setString(2,nom);
        pstmt.setString(3,codeiso);
        pstmt.setString(4,nomdecimal);
        pstmt.setString(5,decimal);
            try {
                    statement=connection.createStatement();
                    pstmt.executeUpdate();
                    response.sendRedirect("client.jsp");
                    
            } catch (SQLException e) {
                    e.printStackTrace();
            }         
            finally{
                    try{
                            connection.close();     
                    }catch (Exception e){
                            e.printStackTrace();
                    }
                    }
    }
    %>
     
     
    <div class="BG">
    	<h4>Modifier Client</h4>	
    </div>
     
    <form>
    <table width ="100%">
    <tr>
    	<td><b>echeance</b></td>
    	<td><input type="text" name="echenace" style="width: 156px" value="<%=eche%>"/></td>
       </tr>
       <tr>
    	<td><b>N° de compte</b></td>
    	<td><input type="text" name="nom" style="width: 156px" value="<%=nom%>"/></td>
       </tr>
       <tr>
    	<td><b>Nom et Prénom</b></td>
     	<td><input type="text" name="codeiso" style="width: 156px" value="<%=codeiso %>"/></td>
       </tr>
       <tr>
        <td><b>Banque</b></td>
     	<td><input type="text" name="nomdecimal" style="width: 156px" value="<%=nomdecimal %>"/></td>
       </tr>
       <tr>
        <td><b>Moyen de payement</b></td>
     	<td><input type="text" name="decimal" style="width: 156px" value="<%=decimal %>"/></td>
       </tr>
       <tr class="BG" width ="150%">
    	<td colspan="4" width ="100%">
    	  <input type="button" value="Valider" onClick="submit()"/>
          <input type="reset" value="Abandonner" style="width: 107px"/>
     
    	</td>
       </tr>
    </table>
    </form>
    </body>
    </html>
    sachant que echeance est de type Date dans ma base MySql, et les autres de type String

  2. #2
    Membre expert
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    2 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 938
    Points : 3 938
    Points
    3 938
    Par défaut
    A moins que je ne connaisse pas cette syntaxe de requete mysql je crois que l'erreur pourrait être là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update utilisateur (echeance,Ncompte,nompre,banque,moypay)VALUES (?,?,?,?,?)WHERE Ncompte= '"+IADEmpl+"'"
    Essaie plutot ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update utilisateur  set echeance=? ,Ncompte=?,nompre=? ,banque=?,moypay=? WHERE Ncompte= '"+IADEmpl+"'"
    Vous avez peut être hâte de réussir et il n'y a rien de mal à cela...
    mais la patience est aussi une vertu; l'échec vous l'enseignera certainement..."

  3. #3
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    merci mais le problème reste le même, CAD, si j'effectue le update sur un variable autre celui de la Date(cad:echeance) il fonctionne parfaitement

    mais

    pour celui de la date il sera remplacer par un null CAD 0000-00-00, même dans le cas où je n'effectue aucunne update pour lui

  4. #4
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    241
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2005
    Messages : 241
    Points : 399
    Points
    399
    Par défaut
    Bonjour,

    peux-tu fournir le contenu de la sortie standard généré par l'exécution de ta servlet?

    Si je peux te recommander une chose, c'est, dans un premier temps, de placer ta logique de traitement dans une classe en dehors de ta JSP. Ca te permettrait de tester ton code sans pour autant avoir à déployer ta page.

    Cordialement,
    Sébastien

  5. #5
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    merci, voila le contenu de la consoler lorsque je veut modifier la date par 22/06/2010

    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
    IADEmpl1=872139
    ssssssss=872139
    IADEmpl1=echenace=22%2F06%2F2010&nom=872139&codeiso=Reber&nomdecimal=BNA&decimal=telecompensation
    IADEmpl=872139
    Exception :
    java.lang.NullPointerException
    	at java.text.SimpleDateFormat.parse(Unknown Source)
    	at java.text.DateFormat.parse(Unknown Source)
    	at org.apache.jsp.Editclient_jsp.testParseDate(Editclient_jsp.java:23)
    	at org.apache.jsp.Editclient_jsp._jspService(Editclient_jsp.java:156)
    	at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:97)
    	at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
    	at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:332)
    	at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:314)
    	at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:264)
    	at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
    	at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:428)
    	at org.mortbay.jetty.servlet.WebApplicationHandler.dispatch(WebApplicationHandler.java:473)
    	at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:568)
    	at org.mortbay.http.HttpContext.handle(HttpContext.java:1530)
    	at org.mortbay.jetty.servlet.WebApplicationContext.handle(WebApplicationContext.java:633)
    	at org.mortbay.http.HttpContext.handle(HttpContext.java:1482)
    	at org.mortbay.http.HttpServer.service(HttpServer.java:909)
    	at org.mortbay.http.HttpConnection.service(HttpConnection.java:820)
    	at org.mortbay.http.HttpConnection.handleNext(HttpConnection.java:986)
    	at org.mortbay.http.HttpConnection.handle(HttpConnection.java:837)
    	at org.mortbay.http.SocketListener.handleConnection(SocketListener.java:245)
    	at org.mortbay.util.ThreadedServer.handle(ThreadedServer.java:357)
    	at org.mortbay.util.ThreadPool$PoolThread.run(ThreadPool.java:534)
    nom=872139
    Exception :
    java.lang.NullPointerException
    	at java.text.SimpleDateFormat.parse(Unknown Source)
    	at java.text.DateFormat.parse(Unknown Source)
    	at org.apache.jsp.client_jsp.testParseDate(client_jsp.java:23)
    	at org.apache.jsp.client_jsp._jspService(client_jsp.java:157)
    	at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:97)
    	at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
    	at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:332)
    	at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:314)
    	at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:264)
    	at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
    	at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:428)
    	at org.mortbay.jetty.servlet.WebApplicationHandler.dispatch(WebApplicationHandler.java:473)
    	at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:568)
    	at org.mortbay.http.HttpContext.handle(HttpContext.java:1530)
    	at org.mortbay.jetty.servlet.WebApplicationContext.handle(WebApplicationContext.java:633)
    	at org.mortbay.http.HttpContext.handle(HttpContext.java:1482)
    	at org.mortbay.http.HttpServer.service(HttpServer.java:909)
    	at org.mortbay.http.HttpConnection.service(HttpConnection.java:820)
    	at org.mortbay.http.HttpConnection.handleNext(HttpConnection.java:986)
    	at org.mortbay.http.HttpConnection.handle(HttpConnection.java:837)
    	at org.mortbay.http.SocketListener.handleConnection(SocketListener.java:245)
    	at org.mortbay.util.ThreadedServer.handle(ThreadedServer.java:357)
    	at org.mortbay.util.ThreadPool$PoolThread.run(ThreadPool.java:534)
    RQ: pour la fonction, je n'est qu'une page JSP dont le principe est de faire une modification, je ne vois pas ni comment je vais la découper pour faire une fonction, ni l'utilité si ma page n'a qu'un seule objectif

  6. #6
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    echenace ? Cela ne vient surement pas de là mais bon, on sait jamais ^^

  7. #7
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    non je croit que c'est de la et plus précisément lorsque le programme prend la date que j'ai mis(CAD 22/06/2010) et la met dans la base je croit que mon problème vient de cette partie mais je n'est aucune idée pour avoir la certitude, il se peut de la forme, mais vraiment aucune idée

    pourquoi je persiste que le problème est a ce niveau, c'est a cause de l'affichage après CAD les modification (autre que la date )s'effectuent parfaitement mais la date est toujours a l'Etat null CAD 000-00-00

    comme s'il y avais une contradiction dans le format ou quelque chose de ce type

  8. #8
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    Il y a un problème de format peut-être. Remplacer les "/" par des "-". Ton entree c dd/mm/yyyy et tu dois mettre yyyy-mm-dd. Autant se mettre le plus pret possible Il y a des fonctions pour changer le format. Enfin, moi je suis un débutant donc je me trompe peut-être. Pis ptet que apres la recup de la date et sa conversion, tu devrais faire des getDay ... et les afficher genre dans ta console ou autre. Comme cela tu verrais si la conversion c'est bien passée . Ca permettrait de cibler un peu plus

  9. #9
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    j'ai vraiment tester les différentes forme possible exp
    0000-00-00
    0000/00/00
    00-00-0000
    00/00/0000

    mais rien aucune de ces formes n'a pus être mis suite a une modification ou même sans modification (car même si je ne modifie pas la date elle se retourne en null)

  10. #10
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    t as répondu avant que l'édition soit passée
    Comme je disais :

    ptet que apres la recup de la date et sa conversion, tu devrais faire des getDay ... et les afficher genre dans ta console ou autre. Comme cela tu verrais si la conversion c'est bien passée . Ca permettrait de cibler un peu plus

  11. #11
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    pis aussi je comprends pas trop le :
    eche = request.getParameter("echeance");
    java.sql.Date maDate = testParseDate(request.getParameter("eche"));

    En fait, tu récupères :
    echenace=22%2F06%2F2010&nom...

    Or d'une c'est echeance et non pas echenace.
    Et d'autres, tu le convertis en java.sql.Date mais tu n'as pas de eche dans ta requete. Ne devrais pas plutot faire :

    String eche = request.getParameter("echeance");
    java.sql.Date maDate = testParseDate(eche); ?

  12. #12
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    oui c'est vrais je n'est pas fait attention a ces information merci
    mais toujours pas de solution C.A.D le problème persiste encore malgré les échanges effectuer

  13. #13
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    Tu as donc corrigé les deux erreurs Surtout le echenace qui était l'erreur indiquée.
    Et si tu fais :
    String eche = request.getParameter("echeance");
    java.sql.Date maDate = testParseDate(("eche"));
    int jour = maDate.getDay();
    int mois = maDate.getMonth();
    int annee = maDate.getYear();

    et puis
    system.out.println(String.valueOf(jour) + "-" + String.valueOf(mois) + "-" + String.valueOf(annee));

    Ca t'affiche quelquechose dans la console ?

  14. #14
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    j'ai une erreur 500
    et pour
    int jour = maDate.getDay();
    int mois = maDate.getMonth();
    int annee = maDate.getYear();

    j'ai
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    The method getDay() from the type Date is deprecated
    The method getMonth() from the type Date is deprecated
    The method getYear() from the type Date is deprecated

  15. #15
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    Arf, je crois que je me suis trompé en t'indiquant une erreur

    C'est testParseDate(eche) et non pas testParseDate("eche")

    Si t'as copié collé, c'est normal que cela plante ^^

    Aller, je vais m'arrêter là ^^

  16. #16
    Nouveau membre du Club
    Inscrit en
    Février 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 86
    Points : 37
    Points
    37
    Par défaut
    vous saviez quelque chose???

    le problème vient de ces deux ""

    enfin c'est résolu merci mil fois pour vous et de votre aide

    enfin depuis hier tout un journée merciiiii

  17. #17
    En attente de confirmation mail
    Profil pro
    Inscrit en
    Février 2009
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 150
    Points : 101
    Points
    101
    Par défaut
    De rien En fait, faut regarder la console et ensuite y aller petit à petit avec des alert() en javascript ou des valeurs dans la console. Elle affichait le : echenance. De plus request.getParameter(eche) alors qu' eche est pas dans la requête. A pluch

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

Discussions similaires

  1. Je ne trouve pas l'erreur dans mon code
    Par true-life dans le forum Débuter
    Réponses: 4
    Dernier message: 25/04/2009, 10h40
  2. je ne trouve pas l'erreur dans mon programme
    Par Briska dans le forum Débuter
    Réponses: 19
    Dernier message: 04/04/2008, 09h21
  3. Gestion des erreurs dans les pages JSP
    Par elewandowski dans le forum Struts 2
    Réponses: 3
    Dernier message: 04/12/2007, 21h18
  4. Inserer la stack d'erreur dans une page JSP
    Par skunkies dans le forum Servlets/JSP
    Réponses: 7
    Dernier message: 25/09/2006, 17h10
  5. Réponses: 4
    Dernier message: 10/08/2006, 13h44

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