salut,
j'essay de me mettre à hibernate et je croi avoire le même problème que celui rencontré ici: http://www.developpez.net/forums/sho....php?t=127909:

j'ai créé un classe HybernateUtil :
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
package util;
 
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.*;
import org.hibernate.cfg.*;
 
public class HibernateUtil {
 
    private static Log log = LogFactory.getLog(HibernateUtil.class);
    private static final SessionFactory sessionFactory;
 
    static {
        try {
            // Create the SessionFactory
            sessionFactory = 
			new Configuration().configure().buildSessionFactory();
        } catch (Throwable ex) {
            // Make sure you log the exception, as it might be swallowed
            log.error("Initial SessionFactory creation failed." + ex);
            throw new ExceptionInInitializerError(ex);
        }
    }
 
    public static final ThreadLocal session = new ThreadLocal();
 
    public static Session currentSession() {
        Session s = (Session) session.get();
        // Open a new Session, if this Thread has none yet
        if (s == null) {
            s = sessionFactory.openSession();
            session.set(s);
        }
        return s;
    }
 
    public static void closeSession() {
        Session s = (Session) session.get();
        if (s != null)
            s.close();
        session.set(null);
    }
}
et j'ai fait un mapping vers objet relationnel (basique pour commancer) avec un de mes beans et la table correspondante :
la classe :
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
package beans;
 
import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.io.Serializable;
 
public class UserType extends Object implements Serializable {
 
    public final String PROP_DATABASE_ID="databaseId";
    public final String PROP_LIBELLE="libelle";
 
    private int databaseId;
    private String libelle;
 
    private PropertyChangeSupport propertySupport;
 
    public UserType() {
        propertySupport = new PropertyChangeSupport(this);
    }
 
    public void addPropertyChangeListener(PropertyChangeListener listener) {
        propertySupport.addPropertyChangeListener(listener);
    }
 
    public void removePropertyChangeListener(PropertyChangeListener listener) {
        propertySupport.removePropertyChangeListener(listener);
    }
 
    public int getDatabaseId() {
        return this.databaseId;
    }
 
    public void setDatabaseId(int databaseId) {
        this.databaseId = databaseId;
    }
 
    public String getLibelle() {
        return this.libelle;
    }
 
    public void setLibelle(String libelle) {
        this.libelle = libelle;
    }
 
}
la table :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
CREATE TABLE IF NOT EXISTS USER_TYPE
 (
   ID_USER_TYPE INTEGER NOT NULL AUTO_INCREMENT ,
   LIBELLE VARCHAR (128) NULL  
   , PRIMARY KEY (ID_USER_TYPE) 
 )
le fichier de mapping correspondant :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="beans.UserType" table="USER_TYPE">
        <id name="databaseId" type="int" column="ID_USER_TYPE" unsaved-value="0">
            <generator class="identity"/>
        </id>
        <property name="libelle" column="LIBELLE" />
    </class>
</hibernate-mapping>
et je teste tout ça avec une servlet tout ce qu'il y a de plus classique :
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
 
import java.io.*;
import java.net.*;
 
import javax.servlet.http.*;
 
import util.HibernateUtil;
import beans.User;
import java.util.Iterator;
import javax.servlet.*;
import javax.servlet.http.*;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
public class TestServlet extends HttpServlet {
 
    /** Processes requests for both HTTP <code>GET</code> and <code>POST</code> methods.
     * @param request servlet request
     * @param response servlet response
     */
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        Session session;
//je n'utililise pas la transaction car de toute façon je n'arrive pas à me connecter :'(:'(
        Transaction tx;
//c'est ici que ça foir, quand j'enlève cette ligne, ça m'affiche ce que je veut, le fait est que je ne me connecte pas :(
        session = HibernateUtil.currentSession();
 
        out.println("<html>");
        out.println("<head>");
        out.println("<title>Servlet TestServlet</title>");
        out.println("</head>");
        out.println("<body>");
        out.println("<h1>Servlet TestServlet at " 
		+ request.getContextPath() + "</h1> by amine ;)");
 
        out.println("</body>");
        out.println("</html>");
        out.close();
//ne sert à rien pour l'instant, mais je le garde pour la posterité :D
        HibernateUtil.closeSession();
    }
 
    // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
    /** Handles the HTTP <code>GET</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        processRequest(request, response);
    }
 
    /** Handles the HTTP <code>POST</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        processRequest(request, response);
    }
 
    /** Returns a short description of the servlet.
     */
    public String getServletInfo() {
        return "Short description";
    }
    // </editor-fold>
}
au cas où ça peut servire, voici mon fichier de configuration de 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
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">
 
<hibernate-configuration>
 
    <session-factory>
 
        <property name="connection.datasource">java:comp/env/jdbc/mariages</property>
        <property name="show_sql">false</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
 
        <!-- fichiers de mapping -->
        <!--
        <mapping resource="Adresse.hbm.xml"/>
        <mapping resource="Article.hbm.xml"/>
        <mapping resource="Couple.hbm.xml"/>
        <mapping resource="Evenement.hbm.xml"/>
        <mapping resource="FamilleArticle.hbm.xml"/>
        <mapping resource="Langue.hbm.xml"/>
        <mapping resource="Liste.hbm.xml"/>
        <mapping resource="Pays.hbm.xml"/>
        <mapping resource="Personne.hbm.xml"/>
        <mapping resource="User.hbm.xml"/>
        <mapping resource="UserType.hbm.xml"/>
        <mapping resource="Ville.hbm.xml"/>
        -->
        <mapping resource="UserType.hbm.xml"/>
 
    </session-factory>
 
</hibernate-configuration>
j'ai suivi un tuto sur le net à la lettre, mais je ne comprends pas pourquoi j'ai toujours les même erreurs :
d'abord :
description Le serveur a rencontr� une erreur interne () qui l'a emp�ch� de satisfaire la requ�te.

exception

javax.servlet.ServletException: L'ex�cution de la servlet a lanc� une exception
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:362)

cause m�re

java.lang.ExceptionInInitializerError
util.HibernateUtil.<clinit>(HibernateUtil.java:36)
TestServlet.processRequest(TestServlet.java:39)
TestServlet.doGet(TestServlet.java:86)
javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:362)
et quand je rafrechie la page, l'erreur change :

description Le serveur a rencontr� une erreur interne () qui l'a emp�ch� de satisfaire la requ�te.

exception

javax.servlet.ServletException: L'ex�cution de la servlet a lanc� une exception
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:362)

cause m�re

java.lang.NoClassDefFoundError
TestServlet.processRequest(TestServlet.java:39)
TestServlet.doGet(TestServlet.java:86)
javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:362)
je ne comprend pas ce qui arrive, aidez un jeune développeure en detresse s'il vous plai :'(,

merci d'avance

PS: j'utilise netbeans 5.0 comme IDE, JDK 1.4.x et hibernate 3.0