Bonsoir à la communauté,
je viens de découvrir la taglib displaytag dans un des tuto du site.
J'ai apprécié la possibilité d'exportation des données du tableau. Cependant, j'ai essayé de le mettre en pratique mais j'y arrive pas.
Je me suis inspiré de quelque poste pour le téléchargement tu tag et son installation.
Mon problème est comment récupéré les données d'une table Etudiant et de l'affiché dans le tableau.
voici mon code :
Mon beans
Mon interface EtudiantDAO et son implémentation
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 public class Etudiant { private int id; private String nom; private String prenom; private int age; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getNom() { return nom; } public void setNom(String nom) { this.nom = nom; } public String getPrenom() { return prenom; } public void setPrenom(String prenom) { this.prenom = prenom; } }
//implémentation
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6 .... public interface EtudiantDAO { //pour lister les etudiants List<Etudiant> liste() throws DAOException; }
J'utilise ensuite un filtre pour précharger la liste dans une session
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 ... public class EtudiantDaoImpl implements EtudiantDao { private DAOFactory daoFactory; private static final String SQL_SELECT_ETUDIANT = "SELECT * FROM Etudiant "; /*Constructeur*/ EtudiantDaoImpl( DAOFactory daoFactory ) { this.daoFactory = daoFactory; } public List <Etudiant> liste() throws DAOException { Connection connection = null; PreparedStatement STMT = null; ResultSet RST = null; List<Etudiant> Etudiant = new ArrayList<Etudiant>(); try { connection = daoFactory.getConnection(); STMT = connection.prepareStatement(SQL_SELECT_PROFIL ); RST = STMT.executeQuery(); while ( RST.next() ) { Etudiant.add( map( RST ) ); } } catch ( SQLException e ) { throw new DAOException( e ); } finally { fermeturesSilencieuses( RST, STMT,connection ); } return Etudiant; } /* Mapping */ private static Etudiant map( ResultSet rs ) throws SQLException { Etudiant Etudiant = new Etudiant(); Etudiant.setId(rs.getInt("id")); Etudiant.setNom(rs.getString( "nom" )); Etudiant.setPrenom(rs.getString( "prenom" )); Etudiant.setAge(rs.getString( "age" )); return Etudiant; } }
Et enfin le code de ma page JSP
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 public class ChargerListe implements Filter { public static final String CONF_DAO_FACTORY ="daofactory"; public static final String ATT_SESSION_ETUDIANT = "etudiant"; private EtudiantDao EtudiantDao; public void init(FilterConfig config ) throws ServletException { /* Récupération d'une instance de nos DAO */ this.EtudiantDao = ( (DAOFactory) config.getServletContext().getAttribute( CONF_DAO_FACTORY )).getEtudiantDao(); } public void doFilter( ServletRequest req, ServletResponse res,FilterChain chain ) throws IOException,ServletException { /* Cast de l'objet request */ HttpServletRequest request = (HttpServletRequest) req; /* Récupération de la session depuis la requête */ HttpSession session = request.getSession(); if ( session.getAttribute( ATT_SESSION_ETUDIANT ) == null ){ List<Etudiant> listeEtudiant = ProfilDao.liste(); Map<Long, Etudiant> mapEtudiant = new HashMap<Long,Etudiant>(); for ( Etudiant etudiant : listeEtudiant ) { mapEtudiant.put( Etudiant.getId(), etudiant ); } session.setAttribute( ATT_SESSION_PROFILS,mapetudiant); } chain.doFilter( request, res ); } public void destroy() { } }
Lorsque j'exécute mon programme j'obtiens ceci
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2<display:table name="sessionScope.etudiant" >
Quelqu'un à une idée?
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2com.beans.Etudiant@1397e5c
![]()
Partager