繁体   English   中英

Hibernate SaxParseException

[英]Hibernate SaxParseException

我正在一个maven项目工作。 Atm我只有实体,映射和配置文件。 我试图用junit测试我的hibernate映射。

我找不到问题。 我可以验证netbeans中的xml文件,但是当我运行我的测试时,我收到以下错误。

netbeans中的验证:

XML validation started.

Checking file:/C:/Users/Err/Documents/NetBeansProjects/PinkSocks/src/main/resources/hibernate.cfg.xml...
Referenced entity at "http://localhost:8080/files/hibernate-configuration-4.0.xsd".
XML validation finished.

错误:

    Initial SessionFactory creation failed.org.hibernate.MappingException: invalid configuration
            at bleh.mihihi.utils.HibernateUtil.buildSessionFactory(HibernateUtil.java:25)
            at bleh.mihihi.utils.HibernateUtil.<clinit>(HibernateUtil.java:16)
            at bleh.mihihi.utils.HibernateUtilTest.setUp(HibernateUtilTest.java:20)
    Caused by: org.hibernate.MappingException: invalid configuration
            at org.hibernate.cfg.Configuration.doConfigure(Configuration.java:2014)
            at org.hibernate.cfg.Configuration.configure(Configuration.java:1931)
            at org.hibernate.cfg.Configuration.configure(Configuration.java:1910)
            at bleh.mihihi.utils.HibernateUtil.buildSessionFactory(HibernateUtil.java:21)
    Caused by: org.xml.sax.SAXParseException; lineNumber: 2; columnNumber: 25; Document is invalid: no grammar found.
            at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:198)

hibernate.cfg.xml中:

    <?xml version="1.0" encoding="UTF-8"?>
    <hibernate-configuration
        xmlns="http://www.hibernate.org/xsd/hibernate-configuration"
        xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
        xsi:schemaLocation="http://www.hibernate.org/xsd/hibernate-configuration http://localhost:8080/files/hibernate-configuration-4.0.xsd">
        <session-factory>
            <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
            <property name="connection.url">jdbc:mysql://localhost/pinksocks</property>
            <property name="connection.username">root</property>
            <property name="connection.password">admin</property>
            <property name="connection.pool_size">1</property>
            <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
            <property name="current_session_context_class">thread</property>
            <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>
            <property name="show_sql">true</property>
            <mapping class="bleh.mihihi.Beverage" file="Beverage.hbm.xml" />
        </session-factory>
    </hibernate-configuration>

Beverage.hbm.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <hibernate-mapping
    xmlns="http://www.hibernate.org/xsd/hibernate-mapping"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://www.hibernate.org/xsd/hibernate-mapping http://localhost:8080/files/hibernate-mapping-4.0.xsd"
        package="bleh.mihihi.entities">
        <class name="Beverage" table="beverages">
            <id name="id" column="id">
                <generator class="native"/>
            </id>
            <property name="name" column="name" />
            <property name="alcohol" column="alcohol"/>
        </class>
    </hibernate-mapping>

提前致谢

EDIT1:

我试过的事情:

  • 重新输入

  • 使用dtd

  • 将xsd放到其他地方

使用Hibernate 4.x,你应该使用与3.x相同的DTD:

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>

正如您可以在此错误报告中看到的那样,删除了弃用警告。 另外4.2版本的教程使用了这个,你可以在这里看到。

你忘了指定DTD。

尝试在xml文件中保留以下代码并告诉我

<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

你忘记了hibernate.cfg.xml文件中的DTD

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM