Java Hibernate找不到Hibernate.cfg.xml文件
我用gradle做了一个java项目,非常简单,它是一个任务管理器,我有一个Person类和一个task类,我想使用hibernate,但是hibernate没有加载Java Hibernate找不到Hibernate.cfg.xml文件,java,hibernate,gradle,Java,Hibernate,Gradle,我用gradle做了一个java项目,非常简单,它是一个任务管理器,我有一个Person类和一个task类,我想使用hibernate,但是hibernate没有加载hibernate.cfg.xml,我尝试了很多解决方案,但都成功了 我有一个HibernateUtil.java这样写的: package org.gradle.util; import org.hibernate.SessionFactory; import org.hibernate.boot.registry.Standa
hibernate.cfg.xml
,我尝试了很多解决方案,但都成功了
我有一个HibernateUtil.java
这样写的:
package org.gradle.util;
import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
public class HibernateUtil {
private static final SessionFactory sessionFactory = buildSessionFactory();
private static SessionFactory buildSessionFactory() {
try {
// Create the SessionFactory from hibernate.cfg.xml
return new Configuration().configure().buildSessionFactory(
new StandardServiceRegistryBuilder().build() );
}
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;
}
}
这是布局图:
/my-project
/src
/main
/java
/org
/gradle
Main.java
/controllers
PersonController.java
TaskController.java
/domains
Person.java
Task.java
Person.hbm.xml
Task.hbm.xml
/util
HibernateUtil.java
/java
/resources
hibernate.cfg.xml
/org
/gradle
/test
/java
/org
/gradle
PersonTest.java
TaskTest.java
这是完整的跟踪:
Sep 26, 2014 11:32:11 AM org.hibernate.annotations.common.reflection.java.JavaReflectionManager <clinit>
INFO: HCANN000001: Hibernate Commons Annotations {4.0.5.Final}
Sep 26, 2014 11:32:11 AM org.hibernate.Version logVersion
INFO: HHH000412: Hibernate Core {4.3.6.Final}
Sep 26, 2014 11:32:11 AM org.hibernate.cfg.Environment <clinit>
INFO: HHH000206: hibernate.properties not found
Sep 26, 2014 11:32:11 AM org.hibernate.cfg.Environment buildBytecodeProvider
INFO: HHH000021: Bytecode provider name : javassist
Sep 26, 2014 11:32:11 AM org.hibernate.cfg.Configuration configure
INFO: HHH000043: Configuring from resource: /hibernate.cfg.xml
Sep 26, 2014 11:32:11 AM org.hibernate.cfg.Configuration getConfigurationInputStream
INFO: HHH000040: Configuration resource: /hibernate.cfg.xml
Initial SessionFactory creation failed.org.hibernate.HibernateException: /hibernate.cfg.xml not found
Exception in thread "main" java.lang.ExceptionInInitializerError
at org.gradle.util.HibernateUtil.buildSessionFactory(HibernateUtil.java:20)
at org.gradle.util.HibernateUtil.<clinit>(HibernateUtil.java:9)
at org.gradle.controllers.PersonController.add(PersonController.java:10)
at org.gradle.Main.main(Main.java:12)
Caused by: org.hibernate.HibernateException: /hibernate.cfg.xml not found
at org.hibernate.internal.util.ConfigHelper.getResourceAsStream(ConfigHelper.java:173)
at org.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:2093)
at org.hibernate.cfg.Configuration.configure(Configuration.java:2074)
at org.hibernate.cfg.Configuration.configure(Configuration.java:2054)
at org.gradle.util.HibernateUtil.buildSessionFactory(HibernateUtil.java:14)
... 3 more
2014年9月26日上午11:32:11 org.hibernate.annotations.common.reflection.java.JavaReflectionManager
信息:HCANN000001:Hibernate Commons注释{4.0.5.Final}
2014年9月26日上午11:32:11 org.hibernate.Version日志版本
信息:hh000412:Hibernate核心{4.3.6.Final}
2014年9月26日上午11:32:11 org.hibernate.cfg.Environment
信息:HH000206:找不到hibernate.properties
2014年9月26日上午11:32:11 org.hibernate.cfg.Environment buildBytecodeProvider
信息:HH000021:字节码提供程序名称:javassist
2014年9月26日上午11:32:11 org.hibernate.cfg.Configuration
信息:HH000043:从资源配置:/hibernate.cfg.xml
2014年9月26日上午11:32:11 org.hibernate.cfg.Configuration getConfigurationInputStream
信息:hh000040:配置资源:/hibernate.cfg.xml
初始SessionFactory创建失败。org.hibernate.hibernateeException:/hibernate.cfg.xml未找到
线程“main”java.lang.ExceptionInInitializeError中出现异常
位于org.gradle.util.HibernateUtil.buildSessionFactory(HibernateUtil.java:20)
位于org.gradle.util.HibernateUtil.(HibernateUtil.java:9)
位于org.gradle.controllers.PersonController.add(PersonController.java:10)
位于org.gradle.Main.Main(Main.java:12)
原因:org.hibernate.HibernateException:/hibernate.cfg.xml未找到
位于org.hibernate.internal.util.ConfigHelper.getResourceAsStream(ConfigHelper.java:173)
位于org.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:2093)
位于org.hibernate.cfg.Configuration.configure(Configuration.java:2074)
位于org.hibernate.cfg.Configuration.configure(Configuration.java:2054)
位于org.gradle.util.HibernateUtil.buildSessionFactory(HibernateUtil.java:14)
... 3个以上
我希望你们能帮助我,这让我心碎。
如果您需要更多信息,请告诉我。根据Hibernate 4+Gradle教程:
您的resources
文件夹应位于main
下,而不是java
下:
编辑:
可能您在构建sessionfactory的过程中遗漏了一些东西:
Configuration configuration = new Configuration().configure();
StandardServiceRegistryBuilder builder = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties());
sessionFactory = configuration.buildSessionFactory(builder.build());
而不是:
return new Configuration().configure().buildSessionFactory(
new StandardServiceRegistryBuilder().build() );
您必须应用设置才能将配置的属性传递给构建器:检查您的类目录,查看
hinernate.cfg.xml
文件是否以正确的路径复制到那里。我不确定gradle是如何工作的,但如果它是Maven,那么我必须检查的路径是target/classes/hibernate.cfg.xml
gradle在根目录上构造一个名为build
的新文件夹,因此当我运行gradle build时,hibernate.cfg.xml
位于/myproject/build/resources/main/hibernate.cfg.xml
将hibernate.cfg.xml
文件放在src文件夹中如果您想仔细检查并确认一切正常,请看一看关于hibernate4+gradle的教程:这应该是有效的,不知道发生了什么,但您可以在这里尝试另一种方法Configuration config=new Configuration().configure(新文件(“configfilepath”)代码>谢谢,但是我把它移到了主
文件夹中,它仍然不能正常工作,错误是:org.hibernate.hibernateeexception:/hibernate.cfg.xml未找到
您需要将配置属性传递给构建器:StandardServiceRegistryBuilder().applySettings(configuration.getProperties())
,见我编辑的答案