Afficher des données sur ma page d'accueil JSP

Afficher des données sur ma page d'accueil JSP - Java - Programmation

Marsh Posté le 14-02-2013 à 15:02:37    

Bonjour à tous,  
 
Je suis assez nouveau en programmation, et je programme ma première application web...  
 
J'expose donc mon problème.  
 
Lors du lancement de mon application, j'arrive sur une page Index.jsp, qui est supposée afficher des données de ma base (il s'agit d'une base de données Derby) rentrées précédemment sur une autre base.
 
Mais vu que c'est ma page d'accueil, je ne passe pas au préalable par une servlet. Y a t'il donc moyen d'aller chercher ces données directement depuis une page JSP via une requête SQL ou quelque chose comme ca ?
 
 
 
Pour voir plus clair, voila une partie du script de ma page :  
 
 

Code :
  1. <div id="intitule">
  2. <font face="Verdana" size="4" color="grey">
  3.    <a id="intitule" class="label" title="Intitule" >Intitule</a>
  4.    </font>
  5.  
  6. </div>
  7. <div id="domaine" >
  8. <font face="Verdana" size="4" color="grey">
  9.    <a id="domaine" class="label" title="domaine" >Domaine</a>
  10.    </font>
  11.  
  12. </div>
  13. <div id="statut" >
  14. <font face="Verdana" size="4" color="grey">
  15.    <a id="statut" class="label" title="statut" >Statut</a>
  16.    </font>


 
 
Donc, j'aimerai, plutôt que d'afficher le mot "Intitule" par exemple, aller piocher dans ma base derby : Intitule, dans la table PROJETS
 
De même pour Domaine, je souhaiterai afficher le Domaine, tiré de la table Projet.  
 
 
Faut il créer une connexion à la base directement dans ma page JSP ? Ou bien faut il créer une servlet qui serait appelée à je ne sais quel moment ?
 
 
 
 
 
Merci d'avance ! =) Puis bonne journée à vous


---------------
Votre vie est régie par ce que les gens attendent de vous
Reply

Marsh Posté le 14-02-2013 à 15:02:37   

Reply

Marsh Posté le 14-02-2013 à 18:12:42    

Tu peux faire cela à partir du jsp, cf
http://www.java2s.com/Code/Java/JSP/Database.htm
 
Mais :
a) les bonnes pratiques disent que (en simplifiant) le codage de ton besoin se fera en :
- tu crées une datasource dans ton serveur d'application
- la servlet accède à la base de données en utilisant la datasource,
  fait la requête,  
  valorises les valeurs qui t’intéressent dans la session ou la request
  et forwarde vers le jsp
- la jsp prends les valeurs dans la request ou la session et les affiches
  rien de plus
Pas sûr que tu comprennes ceci mais  
la raison est que c'est maintenable, extensible, évolutif, robuste etc etc
a) tu vas coder ta page à l'arrache avec tes petites connaissances  
mais tu coderas de la pire des manières  
et je dirai tu vas anti-apprendre à coder et prendre de mauvaises habitudes
c) je ne sais pas quel est ton but à long terme mais si un jour tu cherches un job de développeur java tu ne pourras pas te vanter de tes petits travaux maison


Message édité par willy le kid le 14-02-2013 à 18:14:01
Reply

Marsh Posté le 14-02-2013 à 18:16:13    

Mots clefs si tu te décides à faire de la servlet : mvc servlet jsp

Reply

Marsh Posté le 15-02-2013 à 09:30:49    

Ok, merci beaucoup pour la réponse =)
 
Je vais essayer de suivre les bonnes pratiques ! C'est comme ca qu'on apprend.  
T'en fais pas pour mon but à long terme, je suis en stage dans une entreprise et j'essaie de leur développer une petite application, pas bien compliquée en soit, mais qui permettrait de simplifier deux trois choses
 
Merci encore  
Je te tiens au courant de mon avancement =D

Reply

Marsh Posté le 20-02-2013 à 15:05:54    

Bonjour !  
 
J'ai, je pense, fait tout cela désormais, mais voila, je me frotte à un autre souci maintenant... Et du coup, beh mes données ne s'affichent toujours pas =/
 
J'ai donc ma servlet qui récupère les données de la base et les stocke dans une ArrayList, données que je forwarde à ma JSP.
 
Du coté de la jsp, j'ai créé une boucle foreach, pour adapter la structure de ma page aux données présentes dans la base. Et dans cette boucle foreach, je fais un présumé appel des données forwardées. Cependant, lorsque je lance l'appli, les données sont au mieux "null", ou bien rien du tout n'est affiché (case blanche quoi)... De plus, la structure, beh je voudrais qu'elle s'adapte et qu'elle se reproduise autant de fois qu'il y à de lignes dans ma base (ce a quoi je pense que sert le foreach), mais la ligne n'apparait qu'une fois, et est vide.
 
Bon, je progresse dans le sens où avant je ne savais même pas comment fonctionnait la servlet, mais j'y suis pas encore quoi x)
 
 
Ma page Index.jsp :  
 

Code :
  1. ............Code sans importance au probleme..........
  2.     <c:forEach items="session.getAttribute('projets')" var="projets" >
  3.    
  4. <div id="intitule">
  5. <font face="Verdana" size="4" color="grey">
  6.     <% String e = (String) request.getAttribute("domaine" );
  7.     out.print(e);%>
  8.  
  9.  
  10.  
  11.  
  12.    </font>
  13. </div>
  14. <div id="domaine" >
  15. <font face="Verdana" size="4" color="grey">
  16.    <a id="domaine" class="label" title="domaine" ><%request.getAttribute("domaine" );%></a>
  17.    </font>
  18.  
  19. </div>
  20. <div id="statut" >
  21. <font face="Verdana" size="4" color="grey">
  22.    <a id="statut" class="label" title="statut" >$_Statut</a>
  23.    </font>
  24.  
  25. </div>
  26.     ......Code inintéressant......
  27.     </c:forEach>


 
J'ai même tenté le foreach avec la syntaxe suivante, sauf que cette fois, rien du tout n'apparait, même pas la structure :
 

Code :
  1. <c:forEach items="${sessionScope.AffichageIndex.projet}" var="p">


 
 
 
(Comme on peut le voir, j'ai essayé plusieurs manières différentes d'afficher ces données, rien n'y à fait)  
 
La servlet AffichageIndex.java :
 

Code :
  1. import java.io.IOException;
  2. import java.io.PrintWriter;
  3. import java.sql.Connection;
  4. import java.sql.DriverManager;
  5. import java.sql.ResultSet;
  6. import java.sql.SQLException;
  7. import java.sql.Statement;
  8. import java.util.ArrayList;
  9. import java.util.List;
  10. import javax.servlet.RequestDispatcher;
  11. import javax.servlet.ServletException;
  12. import javax.servlet.http.HttpServlet;
  13. import javax.servlet.http.HttpServletRequest;
  14. import javax.servlet.http.HttpServletResponse;
  15. import javax.servlet.http.HttpSession;
  16. import javax.xml.ws.RequestWrapper;
  17. public class AffichageIndex extends HttpServlet {
  18.   public void doGet(HttpServletRequest request,
  19.       HttpServletResponse response) throws ServletException,
  20.       IOException {
  21.     PrintWriter out = null;
  22.     Connection connection = null;
  23.     Statement statement;
  24.     ResultSet rs;
  25.     try {
  26.      Class.forName("org.apache.derby.jdbc.ClientDriver" );
  27.       connection = DriverManager
  28.           .getConnection("jdbc:derby://localhost:1527/sample;create=true","scott","tiger" );
  29.       statement = connection.createStatement();
  30.       response.setContentType("test/html" );
  31.       out = response.getWriter();
  32.       rs = statement.executeQuery("SELECT numero, statut, domaine, datecreation, datebutoire, intitule, description FROM projets" );
  33.       List<String> projet = new ArrayList<String>();
  34.       while(rs.next()){
  35.        //projets.add(rs.getString(1).toString());
  36.        //projets.add(rs.getString(2).toString());
  37.        //projets.add(rs.getString(3).toString());
  38.        //projets.add(rs.getString(4).toString());
  39.        //projets.add(rs.getString(5).toString());
  40.        //projets.add(rs.getString(6).toString());
  41.        //projets.add(rs.getString(7).toString());
  42.        projet.add(rs.getString("numero" ).toString());
  43.           projet.add(rs.getString("statut" ).toString());
  44.           projet.add(rs.getString("domaine" ).toString());
  45.           projet.add(rs.getString("datecreation" ).toString());
  46.           projet.add(rs.getString("datebutoire" ).toString());
  47.           projet.add(rs.getString("intitule" ).toString());
  48.           projet.add(rs.getString("description" ).toString());
  49.          
  50.           HttpSession session = request.getSession();   
  51.           session.setAttribute("projets", projet);
  52.           request.getRequestDispatcher("../Index.jsp" ).forward(request, response);
  53.       }
  54.  
  55.     } catch (ClassNotFoundException e) {
  56.       out.println("Driver Error" );
  57.     } catch (SQLException e) {
  58.       out.println("SQLException: " + e.getMessage());
  59.     }
  60.     finally {
  61.      try {
  62.     if (connection != null) {
  63.      connection.close();
  64.     }
  65.     }
  66.     catch (SQLException ignored){
  67.     out.println(ignored);
  68.     }
  69.     }
  70.     }
  71.  
  72.  
  73. }


 
 
Donc, la aussi, j'ai essayé plusieurs manières de récupérer les données
 
J'arrive pas a comprendre d'où pourrait venir le problème... Je commence a me taper la tête sur le clavier  
 
Merci d'avance.


Message édité par James Pinkerton le 20-02-2013 à 15:54:56
Reply

Marsh Posté le 22-02-2013 à 13:53:48    

Instrumentes ton code. a tous les niveaux possibles. ajoutes des traces. Fais des System.out (a defaut d utiliser un logger comme log4j)
 
Quand tu fais des projet.add(rs.getString("numero" ).toString());
comment es tu sur que les rs.getString... ramenent une valeur?
 
 

Reply

Marsh Posté le 22-02-2013 à 15:45:08    

willy le kid a écrit :

Instrumentes ton code. a tous les niveaux possibles. ajoutes des traces. Fais des System.out (a defaut d utiliser un logger comme log4j)

 

Quand tu fais des projet.add(rs.getString("numero" ).toString());
comment es tu sur que les rs.getString... ramenent une valeur?

 



 


Ok, donc j'ai modifié mon code... J'arrive désormais à récupérer les informations dans ma arrayList et à avoir un retour sur ma page JSP !
Désolé Willy, a peine tu as le temps de me répondre que j'ai déja un autre problème =s

 

Sur ma JSP, j'arrive a itérer sur les fameuses données. Ma boucle foreach modifie la structure de ma page, et varie selon le nombre d'occurrences que j'ai dans ma base. Mais au moment d'appeler les informations de ma Liste, je ne peux qu'appeler un groupe d'informations.. Je te joins mes pages et je t'explique :

 

Servlet :

Code :
  1. import java.io.IOException;
  2. import java.io.PrintWriter;
  3. import java.sql.Connection;
  4. import java.sql.Date;
  5. import java.sql.DriverManager;
  6. import java.sql.ResultSet;
  7. import java.sql.SQLException;
  8. import java.sql.Statement;
  9. import java.util.ArrayList;
  10. import java.util.List;
  11. import javax.faces.bean.ApplicationScoped;
  12. import javax.faces.bean.SessionScoped;
  13. import javax.servlet.RequestDispatcher;
  14. import javax.servlet.ServletException;
  15. import javax.servlet.http.HttpServlet;
  16. import javax.servlet.http.HttpServletRequest;
  17. import javax.servlet.http.HttpServletResponse;
  18. import javax.servlet.http.HttpSession;
  19. import javax.xml.ws.RequestWrapper;
  20. @ApplicationScoped
  21. @SessionScoped
  22. public class AffichageIndex extends HttpServlet {
  23.   public void doGet(HttpServletRequest request,
  24.       HttpServletResponse response) throws ServletException, NullPointerException,
  25.       IOException {
  26.     PrintWriter out = null;
  27.     Connection connection = null;
  28.     Statement statement;
  29.     ResultSet rs;
  30.     List<Projet> Resultat;
  31.     Resultat = new ArrayList<Projet>();
  32.     try {
  33.      Class.forName("org.apache.derby.jdbc.ClientDriver" );
  34.       connection = DriverManager
  35.           .getConnection("jdbc:derby://localhost:1527/sample;create=true","scott","tiger" );
  36.       statement = connection.createStatement();
  37.       response.setContentType("test/html" );
  38.       out = response.getWriter();
  39.       rs = statement.executeQuery("SELECT numero,intitule, statut, domaine, datecreation, datebutoire, description FROM projets" );
  40.       while(rs.next()){
  41.           int numero = rs.getInt("numero" );
  42.           String intitule = rs.getString("intitule" );
  43.           String statut = rs.getString("statut" );
  44.           String domaine = rs.getString("domaine" );
  45.           Date datecreation = rs.getDate("datecreation" );
  46.           Date datebutoire = rs.getDate("datebutoire" );
  47.           String description = rs.getString("description" );
  48.          
  49.        
  50.           Projet projet=new Projet(numero,intitule,statut,domaine,datecreation,datebutoire,description);
  51.           Resultat.add(projet);
  52.          
  53.          
  54.           HttpSession session = request.getSession();   
  55.           session.setAttribute("resultat", Resultat);
  56.          
  57.    
  58.          
  59.       }
  60.       response.sendRedirect("../Index.jsp" );
  61.       return;
  62.  
  63.     } catch (ClassNotFoundException e) {
  64.       out.println("Driver Error" );
  65.     } catch (SQLException e) {
  66.       out.println("SQLException: " + e.getMessage());
  67.     }
  68.     finally {
  69.      try {
  70.     if (connection != null) {
  71.      connection.close();
  72.     }
  73.     }
  74.     catch (SQLException ignored){
  75.     out.println(ignored);
  76.     }
  77.     }
  78.     }
  79.  
  80.  
  81. }
 


ma jsp :

 
Code :
  1. <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
  2.     pageEncoding="ISO-8859-1"%>
  3. <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
  4. <%@ page import="java.sql.*" %>
  5. <%@ page import="java.util.ArrayList" %><%@ page import="java.util.List" %>
  6. <%@page import="java.sql.*"%>
  7. <%@page import="java.util.*"%>
  8. <%@ page session="true"%>
  9. <%@page import="java.io.*"%>
  10. <%@page import="java.net.*"%>
  11. <%@page import="javax.servlet.*"%>
  12. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  13. <html>
  14. <head>
  15. <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
  16. <TITLE>Page d'accueil : Front office</TITLE>
  17.     <style type="text/css">
  18.   body {
  19.    background-position:right bottom;
  20.     background-image:url(Fond.gif);
  21.     background-attachment:fixed;
  22.     background-repeat:no repeat;
  23. }
  24.   div {
  25.     background-image:url(Banderolle-jaune-et-ombre.gif);
  26. height: 84px;
  27.     background-repeat:repeat-x;
  28.     background-position:left;
  29.     margin-top:5px;
  30.  
  31. }
  32.   a.label{
  33. margin-top:28px;
  34. }
  35.   #modifier{
  36. margin-top:30px;
  37. }
  38.   #intitule{
  39.  
  40. width:100px;
  41. text-align:center;
  42. float:left;
  43. }
  44.   #domaine{
  45. width:100px;
  46. text-align:center;
  47. float:left;
  48.   #statut{
  49. width:100px;
  50. text-align:center;
  51. float:left;
  52.   #creation{
  53. width:100px;
  54. text-align:center;
  55. float:left;
  56. }
  57.   #fin{
  58. width:100px;
  59. text-align:center;
  60. float:left;
  61. }
  62.   #description{
  63. width:186px;
  64. text-align:center;
  65. float:left;
  66. }
  67.   #derniereA{
  68. width:186px;
  69. text-align:center;
  70. float:left;
  71. }
  72.   #modifier{
  73. text-align:center;
  74. float:clear;
  75. margin-top:6px;
  76. }
  77.    </style>
  78.   </HEAD>
  79.     <body>
  80.     <font face="Stencil std" size="6" id="title" class="title" title="document title" >Front office : Liste des projets</font>   
  81.     <br></br><input id="Consulter" type="button" value="Creer un nouveau projet " onClick="javascript:document.location.href='/Suivi De Chantier v0.1/CreerProjet.jsp'" style='font-family: "Book Antiqua", "Times New Roman", Serif'/>
  82.    
  83. <br></br>
  84. <div id="intitule">
  85. <font face="Verdana" size="4" color="grey">
  86.    <a id="intitule" class="label" title="Intitule" >Intitule</a>
  87.  
  88.    </font>
  89.  
  90. </div>
  91. <div>
  92. </div>
  93.      <c:forEach items="${resultat}" var="v">
  94.    
  95. <div id="intitule">
  96. <font face="Verdana" size="4" color="grey">
  97.    <a id="intitule" class="label" title="intitule" ><c:out value="${v}"></c:out></a>
  98.    </font>
  99.  
  100. <div>
  101. <input id="modifier" type="button" value="Modifier ce projet !" onClick="javascript:document.location.href='ModifierProjet.jsp'" style='font-family: "Book Antiqua", "Times New Roman", Serif'/>
  102.     <BR></br>
  103.     <input id="Consulter" type="button" value="Consulter les actions réalisées  !" onClick="javascript:document.location.href='ConsulterProjet.jsp'" style='font-family: "Book Antiqua", "Times New Roman", Serif'/>
  104.    
  105.  
  106. </div>
  107.      </c:forEach>
  108.           </body>
  109. </html>
  

Donc, comme tu peux le voir, sur ma JSP, j'appelle l'information v, grace à la balise <c:out value="${v}"></c:out>... elle me retourne les listes Projets complètes... Cela donne un résultat qui ressemble à ca :

 

Projet [numero=7, intitule=ok, statut=C, domaine=DIVERS, datecreation=2013-02-22, datebutoire=2015-01-01, description=Une Description] (C'est donc ce qui s'affiche dans mon tableau littéralement)

 

Par contre, j'aimerai n'afficher que l'information intitulé à cet endroit la par exemple

 

Mais quand je précise que l'information que je veux est v.intitulé (ce que je suppose qu'il faut faire) il me retourne une erreur....

 

J'en conclut que ce "Projet [numero=7, i/.../on]" est compté comme une chaine de caractères à part entiere.. N'est ce pas ?

 

Mais comment est ce que je peux récupérer seulement l'information qui m'intéresse ? ='(

 

Je commence à me taper la tete sur le clavier... à chaque fois que j'arrive à surpasser une erreur, j'en ai une autre derriere !

 

Dans tous les cas, merci pour ton précédent message, j'ai sauvé les valeurs dans des variables associées et grâce à ca je peux voir qu'il y à bel et bien quelque chose derriere ! =)

  

à bientôt ! Merci encore pour ta patience exemplaire


Message édité par James Pinkerton le 22-02-2013 à 15:47:35
Reply

Marsh Posté le 22-02-2013 à 22:35:46    

tu cherches le resultat.projet.intitule et tu mets projet sous la var "v"
donc je suppose
<c:out value="${v.intitule}"></c:out>
 
ou alors fouilles dans les tutoriaux JSTL
http://www.developpez.net/forums/d [...] c-foreach/

Reply

Marsh Posté le 25-02-2013 à 10:06:40    

EDIT :  
 
Oulah, autant pour moi, ca marche nickel !  
 
Pour je ne sais quelle raison, ma classe était en private... Ca ne risquait pas de fonctionner !
 
 
Dans tous les cas, avec le <c:out value="${v.intitule}"></c:out>, ca marche super !  
 
 
 
Merci beaucoup Willy =D
 
 
Je met ce post en résolu ! (Il en aura fallu du temps x) )


Message édité par James Pinkerton le 25-02-2013 à 10:51:57

---------------
Votre vie est régie par ce que les gens attendent de vous
Reply

Sujets relatifs:

Leave a Replay

Make sure you enter the(*)required information where indicate.HTML code is not allowed