hibernate buildSessionFactory ClassFormatError:

时间:2012-11-02 12:35:15

标签: java hibernate java-ee

ClassFormatError:方法中的Absent Code属性,在类文件javax / persistence / InheritanceType

中不是本机的或抽象的

尝试构建sessionFactory时遇到此错误 我的hibernate.cfg.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="hibernate.bytecode.use_reflection_optimizer">false</property>
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.username">mateusz</property>
        <property name="hibernate.connection.password">mateusz123</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/carpool</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="show_sql">true</property>
        <mapping class="org.mathew.data.User"></mapping>
    </session-factory>
</hibernate-configuration>

我的HibernateUtil类:

public class HibernateUtil {

    private static final SessionFactory sessionFactory = buildSessionFactory();

    private static SessionFactory buildSessionFactory() {
        try {
            // Create the SessionFactory from hibernate.cfg.xml
            return new AnnotationConfiguration().configure().buildSessionFactory();

        }
        catch (Throwable ex) {
            // Make sure you log the exception, as it might be swallowed
            System.err.println("Initial SessionFactory creation failed." + ex);
            throw new ExceptionInInitializerError(ex);
        }
    }

    public static SessionFactory getSessionFactory() {
        return sessionFactory;
    }

    public static void shutdown() {
        // Close caches and connection pools
        getSessionFactory().close();
    }

}

堆栈跟踪:

Exception in thread "main" java.lang.ExceptionInInitializerError
    at org.mathew.hibutil.HibernateUtil.buildSessionFactory(HibernateUtil.java:19)
    at org.mathew.hibutil.HibernateUtil.<clinit>(HibernateUtil.java:8)
    at org.mathew.mysql.MySqlQueries.<init>(MySqlQueries.java:16)
    at org.mathew.test.AppMain.main(AppMain.java:8)
Caused by: java.lang.ClassFormatError: Absent Code attribute in method that is not native or abstract in class file javax/persistence/InheritanceType
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:791)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
    at org.hibernate.cfg.InheritanceState.extractInheritanceType(InheritanceState.java:51)
    at org.hibernate.cfg.InheritanceState.<init>(InheritanceState.java:21)
    at org.hibernate.cfg.AnnotationBinder.buildInheritanceStates(AnnotationBinder.java:2146)
    at org.hibernate.cfg.AnnotationConfiguration.processArtifactsOfType(AnnotationConfiguration.java:492)
    at org.hibernate.cfg.AnnotationConfiguration.secondPassCompile(AnnotationConfiguration.java:277)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1319)
    at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:915)
    at org.mathew.hibutil.HibernateUtil.buildSessionFactory(HibernateUtil.java:13)
    ... 3 more

我的图书馆:

cglib
commons-collections
commons-logging
dom4j
hibernate3
hibernate-annotations
hibernate-commons-annotations
hibernate-core
java-api-6.0
javassist
jta
log4j
mysql-connector-java
persistence-api
slf4j
slf4j-log4j

我无法上传图片:)

如果有人可以提供帮助,我将感激不尽。 谢谢! :)

1 个答案:

答案 0 :(得分:0)

您似乎手动管理依赖项,您应该使用依赖项管理器(maven,ivy with ant等)以确保获得正确的依赖项(所有libs 在其预期版本中< / em>的)。由于您未指定所使用的库的版本,因此存在以下几种可能的问题:

  • 与hibernate
  • 的persistence-api版本不兼容
  • 不兼容的hibernate jar混合:你显然有一个hibernate3 jar和hibernate-core,这似乎不对。它看起来像旧版本的Hibernate与最近的罐子混合在一起。因此,如果jar首先出现在类路径中,那么仅存在于最新版本中的类可能正在访问旧类中的类。