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

Taglibs Java Discussion :

Servlets et Displaytag : problème d'affichage des données


Sujet :

Taglibs Java

  1. #1
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2007
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Burkina Faso

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

    Informations forums :
    Inscription : Mars 2007
    Messages : 310
    Points : 133
    Points
    133
    Par défaut Servlets et Displaytag : problème d'affichage des données
    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

    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;
    	}
    }
    Mon interface EtudiantDAO et son 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;
       }
    //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
    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;
    	}	
    }
    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
     
    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() {
    	}
    }
    Et enfin le code de ma page JSP
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <display:table name="sessionScope.etudiant" >
    Lorsque j'exécute mon programme j'obtiens ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
       com.beans.Etudiant@1397e5c
    Quelqu'un à une idée?

  2. #2
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2007
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Burkina Faso

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

    Informations forums :
    Inscription : Mars 2007
    Messages : 310
    Points : 133
    Points
    133
    Par défaut
    Je viens d'explorer le forum mais toujours rien

  3. #3
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2007
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Burkina Faso

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

    Informations forums :
    Inscription : Mars 2007
    Messages : 310
    Points : 133
    Points
    133
    Par défaut
    enfin!mon tableau s'affiche
    mon problème se trouvait au niveau du bean

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 02/03/2013, 09h49
  2. [JXTreeTable] Problème d'affichage des données
    Par grabriel dans le forum AWT/Swing
    Réponses: 7
    Dernier message: 01/03/2007, 19h37
  3. [MySQL] Problème avec affichage des données d'une base MySQL
    Par leclone dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 27/12/2006, 12h40
  4. [MySQL] Problème d'affichage des données!
    Par ghyosmik dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 18/09/2006, 15h43
  5. [JTable] Problème d'affichage des données
    Par ddams dans le forum Composants
    Réponses: 2
    Dernier message: 15/09/2004, 17h07

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