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

Struts 1 Java Discussion :

problème d'affichage d'une table dans une JSP


Sujet :

Struts 1 Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Décembre 2009
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Décembre 2009
    Messages : 38
    Par défaut problème d'affichage d'une table dans une JSP
    Bonjour,

    je suis débutant en developpement struts et hibernate, et j'essaye d'afficher quelques colonnes d'une table de ma base de données dans une JSP, en suivant ce tuto: http://viralpatel.net/blogs/2009/06/...ag-struts.html.

    Mais j'ai pas réussi ma tentative, car j'ai cette exception que je ne sais pas comment la resoudre:

    org.apache.jasper.JasperException: javax.servlet.ServletException: java.lang.NullPointerException


    Voici mon code, pour mieux comprendre le problème:

    le bean FArticle.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
     
    package com.hibernate.application2;
     
    import java.math.BigDecimal;
     
    /**
     * FArticle entity. @author MyEclipse Persistence Tools
     */
    public class FArticle extends AbstractFArticle implements java.io.Serializable {
     
    	// Constructors
     
    	/** default constructor */
    	public FArticle() {
    	}
     
    	/** minimal constructor */
    	public FArticle(FArticleId id, String desArt, String codFam) {
    		super(id, desArt, codFam);
    	}
     
    	/** full constructor */
    	public FArticle(FArticleId id, String desArt, String codMes, String codFam,
    			Double priRevien, Integer priVente, Integer mntConsom,
    			Integer mntOuvre, Integer priPub, Byte codRayon, String typArt,
    			BigDecimal txTva, String actif, String ean) {
    		super(id, desArt, codMes, codFam, priRevien, priVente, mntConsom,
    				mntOuvre, priPub, codRayon, typArt, txTva, actif, ean);
    	}
     
    }
    le FArticleDAO.java généré par hibernate:
    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
     
    public class FArticleDAO extends BaseHibernateDAO {
    	private static final Log log = LogFactory.getLog(FArticleDAO.class);
    	// property constants
    	public static final String DES_ART = "desArt";
    	public static final String COD_MES = "codMes";
    	public static final String COD_FAM = "codFam";
    	public static final String PRI_REVIEN = "priRevien";
    	public static final String PRI_VENTE = "priVente";
    	public static final String MNT_CONSOM = "mntConsom";
    	public static final String MNT_OUVRE = "mntOuvre";
    	public static final String PRI_PUB = "priPub";
    	public static final String COD_RAYON = "codRayon";
    	public static final String TYP_ART = "typArt";
    	public static final String ACTIF = "actif";
    	public static final String EAN = "ean";
     
    	public void save(FArticle transientInstance) {
    		log.debug("saving FArticle instance");
    		try {
    			getSession().save(transientInstance);
    			log.debug("save successful");
    		} catch (RuntimeException re) {
    			log.error("save failed", re);
    			throw re;
    		}
    	}
     
    	public void delete(FArticle persistentInstance) {
    		log.debug("deleting FArticle instance");
    		try {
    			getSession().delete(persistentInstance);
    			log.debug("delete successful");
    		} catch (RuntimeException re) {
    			log.error("delete failed", re);
    			throw re;
    		}
    	}
     
    	public FArticle findById(com.hibernate.application2.FArticleId id) {
    		log.debug("getting FArticle instance with id: " + id);
    		try {
    			FArticle instance = (FArticle) getSession().get(
    					"com.hibernate.application2.FArticle", id);
    			return instance;
    		} catch (RuntimeException re) {
    			log.error("get failed", re);
    			throw re;
    		}
    	}
     
    	public List findByExample(FArticle instance) {
    		log.debug("finding FArticle instance by example");
    		try {
    			List results = getSession().createCriteria(
    					"com.hibernate.application2.FArticle").add(
    					Example.create(instance)).list();
    			log.debug("find by example successful, result size: "
    					+ results.size());
    			return results;
    		} catch (RuntimeException re) {
    			log.error("find by example failed", re);
    			throw re;
    		}
    	}
     
    	public List findByProperty(String propertyName, Object value) {
    		log.debug("finding FArticle instance with property: " + propertyName
    				+ ", value: " + value);
    		try {
    			String queryString = "from FArticle as model where model."
    					+ propertyName + "= ?";
    			Query queryObject = getSession().createQuery(queryString);
    			queryObject.setParameter(0, value);
    			return queryObject.list();
    		} catch (RuntimeException re) {
    			log.error("find by property name failed", re);
    			throw re;
    		}
    	}
     
    	public List findByDesArt(Object desArt) {
    		return findByProperty(DES_ART, desArt);
    	}
     
    	public List findByCodMes(Object codMes) {
    		return findByProperty(COD_MES, codMes);
    	}
     
    	public List findByCodFam(Object codFam) {
    		return findByProperty(COD_FAM, codFam);
    	}
     
    	public List findByPriRevien(Object priRevien) {
    		return findByProperty(PRI_REVIEN, priRevien);
    	}
     
    	public List findByPriVente(Object priVente) {
    		return findByProperty(PRI_VENTE, priVente);
    	}
     
    	public List findByMntConsom(Object mntConsom) {
    		return findByProperty(MNT_CONSOM, mntConsom);
    	}
     
    	public List findByMntOuvre(Object mntOuvre) {
    		return findByProperty(MNT_OUVRE, mntOuvre);
    	}
     
    	public List findByPriPub(Object priPub) {
    		return findByProperty(PRI_PUB, priPub);
    	}
     
    	public List findByCodRayon(Object codRayon) {
    		return findByProperty(COD_RAYON, codRayon);
    	}
     
    	public List findByTypArt(Object typArt) {
    		return findByProperty(TYP_ART, typArt);
    	}
     
    	public List findByActif(Object actif) {
    		return findByProperty(ACTIF, actif);
    	}
     
    	public List findByEan(Object ean) {
    		return findByProperty(EAN, ean);
    	}
     
    	public List findAll() {
    		log.debug("finding all FArticle instances");
    		try {
    			String queryString = "from FArticle";
    			Query queryObject = getSession().createQuery(queryString);
    			return queryObject.list();
    		} catch (RuntimeException re) {
    			log.error("find all failed", re);
    			throw re;
    		}
    	}
     
    	public FArticle merge(FArticle detachedInstance) {
    		log.debug("merging FArticle instance");
    		try {
    			FArticle result = (FArticle) getSession().merge(detachedInstance);
    			log.debug("merge successful");
    			return result;
    		} catch (RuntimeException re) {
    			log.error("merge failed", re);
    			throw re;
    		}
    	}
     
    	public void attachDirty(FArticle instance) {
    		log.debug("attaching dirty FArticle instance");
    		try {
    			getSession().saveOrUpdate(instance);
    			log.debug("attach successful");
    		} catch (RuntimeException re) {
    			log.error("attach failed", re);
    			throw re;
    		}
    	}
     
    	public void attachClean(FArticle instance) {
    		log.debug("attaching clean FArticle instance");
    		try {
    			getSession().lock(instance, LockMode.NONE);
    			log.debug("attach successful");
    		} catch (RuntimeException re) {
    			log.error("attach failed", re);
    			throw re;
    		}
    	}
    }
    Le form bean ListeArticlesForm.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
     
    public class ListeArticlesForm extends ActionForm {
    	/*
    	 * Generated Methods
    	 */
     
    	/**
             * 
             */
    	private static final long serialVersionUID = 1L;
    	/** 
             * Method reset
             * @param mapping
             * @param request
             */
     
    	private List<FArticle> articles;
     
     
    	public List<FArticle> getArticles() {
    		return articles;
    	}
     
    	public void setArticles(List<FArticle> article) {
    		this.articles = article;
    	}
     
     
     
    }
    L'action ListeArticlesAction.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
     
    public class ListeArticlesAction extends Action {
    	private static final FArticleDAO FArticleDAO = null;
    @SuppressWarnings("unchecked")
    	public ActionForward execute(ActionMapping mapping, ActionForm form,
    			HttpServletRequest request, HttpServletResponse response) {
     
     
    		ListeArticlesForm listeArticlesForm = (ListeArticlesForm) form;
    		FArticleDAO articledao = FArticleDAO; 
     
    		listeArticlesForm.setArticles(articledao.findAll());
    		return mapping.findForward("showList");
     
    	}
    }
    les JSPs:

    index.jsp
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <%@page contentType="text/html"%>
    	<%@page pageEncoding="UTF-8"%>
     
    	<jsp:forward page="MylisteArticles.do"/>
    listeArticles.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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
    <%@ page language="java" pageEncoding="ISO-8859-1"%>
     
    <%@ taglib uri="http://struts.apache.org/tags-bean" prefix="bean" %>
    <%@ taglib uri="http://struts.apache.org/tags-html" prefix="html" %>
    <%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic" %>
    <%@ taglib uri="http://struts.apache.org/tags-tiles" prefix="tiles" %>
     <%@ taglib uri="http://displaytag.sf.net" prefix="display" %>
     
     
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html:html lang="true">
      <head>
        <html:base />
     
        <title>listeArticle.jsp</title>
     
    	<meta http-equiv="Content-Type"  content="text/html; charset=UTF-8">
    	<meta http-equiv="pragma" content="no-cache">
    	<meta http-equiv="cache-control" content="no-cache">
    	<meta http-equiv="expires" content="0">    
    	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    	<meta http-equiv="description" content="This is my page">
    	<!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
     
      </head>
     
      <body>
      <h2>Liste des articles existants:</h2><br>
        <display:table export="true"
                        name="sessionScope.ListeArticlesForm.articles"
    	                requestURI="MylisteArticles" pagesize="20" >
     
    			<display:column property="id" title="Code" />
    			<display:column property="desArt" title="Designation" />
    			<display:column property="priVente" title="P.U" />
    			<display:column property="typArt" title="Type Article" />
    </display:table>
      </body>
    </html:html>
    struts-config.xml
    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
     
    <form-beans >
     
         <form-bean name="ListeArticlesForm" type="com.ensi.struts.form.ListeArticlesForm" /> 
     
      </form-beans>
     
    <action
          attribute="ListeArticlesForm"
          name="ListeArticlesForm"
          path="/MylisteArticles"
          scope="session"
          type="com.ensi.struts.action.ListeArticlesAction">
          <forward name="showList" path="/listeArticles.jsp" /> 
        </action>
    ET le web.xml
    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
     
    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee   http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
      <servlet>
        <servlet-name>action</servlet-name>
        <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
        <init-param>
          <param-name>config</param-name>
          <param-value>/WEB-INF/struts-config.xml</param-value>
        </init-param>
        <init-param>
          <param-name>debug</param-name>
          <param-value>3</param-value>
        </init-param>
        <init-param>
          <param-name>detail</param-name>
          <param-value>3</param-value>
        </init-param>
        <load-on-startup>0</load-on-startup>
      </servlet>
      <servlet-mapping>
        <servlet-name>action</servlet-name>
        <url-pattern>*.do</url-pattern>
      </servlet-mapping>
      <welcome-file-list>
        <welcome-file>./index.jsp</welcome-file>
      </welcome-file-list>
    </web-app>
    je vous remercie pour votre entraide

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

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par ikouhan Voir le message
    org.apache.jasper.JasperException: javax.servlet.ServletException: java.lang.NullPointerException
    Un peu light

    Peux-tu mettre toute la pile ?
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre averti
    Inscrit en
    Décembre 2009
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Décembre 2009
    Messages : 38
    Par défaut
    Merci pour votre réponse,
    voici toute la pile d'exception:

    exception

    org.apache.jasper.JasperException: javax.servlet.ServletException: java.lang.NullPointerException
    org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:491)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:401)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)


    cause mère

    javax.servlet.ServletException: java.lang.NullPointerException
    org.apache.struts.action.RequestProcessor.processException(RequestProcessor.java:535)
    org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:433)
    org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236)
    org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196)
    org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:414)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    org.apache.jasper.runtime.PageContextImpl.doForward(PageContextImpl.java:706)
    org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:677)
    org.apache.jsp.index_jsp._jspService(index_jsp.java:58)
    org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)


    cause mère

    java.lang.NullPointerException
    com.ensi.struts.action.ListeArticlesAction.execute(ListeArticlesAction.java:48)
    org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:431)
    org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236)
    org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196)
    org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:414)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    org.apache.jasper.runtime.PageContextImpl.doForward(PageContextImpl.java:706)
    org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:677)
    org.apache.jsp.index_jsp._jspService(index_jsp.java:58)
    org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

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

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Tu as la cause ici
    com.ensi.struts.action.ListeArticlesAction.execute(ListeArticlesAction.java:48)
    Regarde dans ton source à quoi correspond la ligne 48.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre averti
    Inscrit en
    Décembre 2009
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Décembre 2009
    Messages : 38
    Par défaut
    Bonjour,

    la ligne 48 de ListeArticlesAction correspond à cette ligne:

    listeArticlesForm.setArticles(articledao.findAll());

    Le problème est avec la méthode finAll(), je ne sais pas pourquoi la méthode findAll() ne s'exécute pas!!

    j'ai changé le code de l'action de cette manière :
    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
     
    public ActionForward execute(ActionMapping mapping, ActionForm form,
    			HttpServletRequest request, HttpServletResponse response) {
     
     
    		ListeArticlesForm listeArticlesForm = (ListeArticlesForm) form;
     
                    List articlesList ;
    		FArticleDAO articledao = FArticleDAO; 
     
    		articlesList = (List) articledao.findAll();
     
     
    		request.getSession().setAttribute("articlesList",articlesList);
     
    		return mapping.findForward("showList");
     
    	}
    }
    Mai toujours l'erreur demeure à cette ligne:
    articlesList = (List) articledao.findAll();

    je ne sais pas quoi faire?

    merci de me répondre

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

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ...
    FArticleDAO articledao = FArticleDAO; 
    articlesList = (List) articledao.findAll();
    ...
    Et où instancies-tu FArticleDAO ?

    Il y a de forte chance de articledao soit NULL...
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

Discussions similaires

  1. copier une table d'une BDD dans une table d'une autre BDD
    Par faniette dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/05/2013, 10h17
  2. Réponses: 7
    Dernier message: 25/03/2011, 10h52
  3. [AC-2003] insert des données d'une table dans une table d'une base externe
    Par marieo dans le forum VBA Access
    Réponses: 1
    Dernier message: 30/11/2009, 14h29
  4. Réponses: 2
    Dernier message: 02/06/2006, 11h26
  5. Mettre une valeur d'une table dans une variable
    Par Raphou96 dans le forum Access
    Réponses: 5
    Dernier message: 06/02/2006, 15h19

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