工程环境:
IDE: eclipse3.5
插件:HibernateSynchronizer
eclipse工程中添加HibernateSynchronizer插件后,编写一个测试用例,测试出错。出错信息:
严重: Error parsing XML: /hibernate.cfg.xml(3) Document is invalid: no grammar found.
2009-10-12 14:05:55 org.hibernate.util.XMLHelper$ErrorLogger error
严重: Error parsing XML: /hibernate.cfg.xml(3) Document root element "hibernate-configuration", must match DOCTYPE root "null".
Exception in thread "main" org.hibernate.MappingException: invalid configuration
其中的hibernate.cfg.xml(3)中的3也可能是其他数字。出现这个错误的原因HibernateSynchronizer自动生成的hibernate.cfg.xml缺少了开头的声明:
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
可是为什么这个插件生成的hibernate.cfg.xml没有开头的DOCTYPE的声明呢?这么明显的错误hibernatesynchornize开发组怎么会没发现呢?
再多试几次,才发现,由这个插件第一次生成的hibernate.cfg.xml是有开头的DOCTYPE声明的,但是当你从一个hbm映射文件执行Add Mapping Reference的时候,不知为什么开头的DOCTYPE就会被刷没掉了(明显是开发组疏忽的BUG)。
解决方法: 不要用Add Mapping Reference,自己手写,或者在用了之后再补上DOCTYPE.
by NN 2009-10-12