【问题标题】:Exception in hibernate休眠中的异常
【发布时间】:2014-07-12 08:14:19
【问题描述】:

我正在尝试在 Eclipse 中开发一个动态 Web 项目。我正在使用休眠 3,tomcat 6。我的网页有一个简单的注册表单。它接受用户数据并将其添加到数据库中。 我正在使用休眠来完成那部分。 我收到这个错误。尝试了一些类似问题中给出的解决方案,但无法解决问题。 我得到的错误是

log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
May 23, 2014 10:20:30 AM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet NavigationController threw exception
org.hibernate.HibernateException: Could not parse configuration: hibernate.cfg.xml
    at org.hibernate.cfg.Configuration.doConfigure(Configuration.java:1491)
    at org.hibernate.cfg.Configuration.configure(Configuration.java:1425)
    at com.pkg.dao.UserDAO.registeruser(UserDAO.java:58)
    at com.pkg.controller.NavigationController.doPost(NavigationController.java:60)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    at java.lang.Thread.run(Unknown Source)
Caused by: org.dom4j.DocumentException: hibernate.sourceforge.net Nested exception: hibernate.sourceforge.net
    at org.dom4j.io.SAXReader.read(SAXReader.java:484)
    at org.hibernate.cfg.Configuration.doConfigure(Configuration.java:1481)
    ... 17 more

我的 Customer.hbm.xml 文件是

<?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="com.pkg.bean.CustomerBean" table="r_customer">      
      <id name="CUSTOMERID"  column="CUSTOMERID" type="String">
         <generator class="assigned"/>
      </id>      
      <property name="PASSWORD" column="PASSWORD" type="String"/>
      <property name="CUSTOMERNAME" column="CUSTOMERNAME" type="String"/>
      <property name="CONTACTNUMBER" column="CONTACTNUMBER" type="String"/>     
   </class>
</hibernate-mapping>

而通过休眠配置文件是

<?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>
        <!-- Database connection settings -->
        <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
        <property name="connection.url">jdbc:oracle:thin:@localhost:1521:javadb</property>
        <property name="connection.username">user</property>
        <property name="connection.password">password</property>
        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">1</property>
        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.OracleDialect</property>
        <!-- Enable Hibernate's automatic session context management -->
        <property name="current_session_context_class">thread</property>
        <!-- Disable the second-level cache -->
        <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>
        <!-- Drop and re-create the database schema on startup -->
             <property name="hbm2ddl.auto"></property>
             <mapping resource="Customer.hbm.xml"/>

    </session-factory>
</hibernate-configuration>

谁能帮我解决这个问题。

【问题讨论】:

    标签: java xml eclipse hibernate


    【解决方案1】:

    你有空

    <property name="hbm2ddl.auto"></property>
    

    把一些价值放在那里update/create

    【讨论】:

      【解决方案2】:

      我对代码所做的更改以使其正常工作

      在我的Customer.hbm.xml 文件中 我将列的类型从type="String" 更改为type="string"

      hibernate.cfg.xml 文件中,我已经在数据库中创建了表,所以 我评论了&lt;property name="hbm2ddl.auto"&gt;create&lt;/property&gt;

      问题似乎是特定于系统的,因为代码在我的家用计算机上正常运行,但显示 org.hibernate.HibernateException: Could not parse configuration: hibernate.cfg.xml 我的办公室电脑出错。

      我在家里使用 Eclipse Kepler、Tomcat 7 和 hibernate 3.6.4 Final

      在办公室有 Eclipse Galileo、Tomcat 6 和 hibernate 3.x.x

      我不太确定要真正解决问题还是问题首先出现。

      【讨论】:

        【解决方案3】:

        我注意到您的 hibernate.cfg.xml 引用了 Customer.hbm.xml,而该文件引用了一个类 com.pkg.bean.CustomerBean。它可能没有错,但它不遵循约定,所以我怀疑那里 可能 那里有问题:

        根据这些约定,hbm.xml 文件将存储在与其类相同的包中。如果是这种情况,您可能应该将其引用为com/pkg/bean/Customer.hbm.xml

        另一个约定是使用与hbm.xml 文件相同的名称来命名文件。那么它就是CustomerBean.hbm.xml

        这只是一个猜测,基于您发布的信息。我不确定这些“约定”中的任何一个是否是违反会导致异常的规则(自从我阅读文档以来已经很长时间了,而且我通常遵循最佳实践,所以我从未测试过如果我不这样做会发生什么t)。

        【讨论】:

        • 遵循约定总是有帮助的。很难找到。在编写代码时我会牢记这一点。
        猜你喜欢
        • 2011-02-14
        • 1970-01-01
        • 1970-01-01
        • 2014-08-22
        • 2011-09-20
        • 2017-07-06
        • 2012-02-24
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多