2013-03-06 127 views
4

我想用Hibernate和Maven启动项目。Hibernate异常hibernate.cfg.xml找不到

我得到了这样的例外:

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". 
SLF4J: Defaulting to no-operation (NOP) logger implementation 
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details. 
Exception in thread "main" org.hibernate.HibernateException: /hibernate.cfg.xml not found 
    at org.hibernate.util.ConfigHelper.getResourceAsStream(ConfigHelper.java:170) 
    at org.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:2176) 
    at org.hibernate.cfg.Configuration.configure(Configuration.java:2157) 
    at org.hibernate.cfg.Configuration.configure(Configuration.java:2137) 
    at FirstHibernate.com.myhib.CRUDS.CrudsOps.main(CrudsOps.java:15) 

这里是我的项目结构的屏幕截图,(hibernate.cfg.xml文件在src /): http://imageshack.us/photo/my-images/692/screenshotxba.jpg/

CrudsOps.java

package FirstHibernate.com.myhib.CRUDS; 

import org.hibernate.Session; 
import org.hibernate.SessionFactory; 
import org.hibernate.cfg.Configuration; 

public class CrudsOps { 

    /** 
    * @param args 
    */ 
    public static void main(String[] args) { 
     // TODO Auto-generated method stub 

     SessionFactory sf = new Configuration().configure().buildSessionFactory(); 
     System.out.println("Cfg and hbm files loaded succesfully"); 
     Session session = sf.openSession(); 
     session.beginTransaction(); 
     System.out.println("Transaction began"); 

    } 

} 

的pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 
    <groupId>FirstHibernate</groupId> 
    <artifactId>com.myhib</artifactId> 
    <packaging>war</packaging> 
    <version>0.0.1-SNAPSHOT</version> 
    <name>com.myhib Maven Webapp</name> 
    <url>http://maven.apache.org</url> 
    <dependencies> 
    <dependency> 
     <groupId>junit</groupId> 
     <artifactId>junit</artifactId> 
     <version>3.8.1</version> 
     <scope>test</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.hibernate</groupId> 
     <artifactId>hibernate-core</artifactId> 
     <version>3.6.8.Final</version> 
    </dependency> 
    <dependency> 
     <groupId>postgresql</groupId> 
     <artifactId>postgresql</artifactId> 
     <version>9.1-901.jdbc4</version> 
    </dependency> 
    <dependency> 
     <groupId>org.hibernate</groupId> 
     <artifactId>hibernate-validator</artifactId> 
     <version>4.2.0.Final</version> 
    </dependency> 
    </dependencies> 
    <build> 
    <finalName>com.myhib</finalName> 
    <resources> 
     <resource> 
      <filtering>true</filtering> 
      <directory>src/main/resources</directory> 
     </resource> 
    </resources> 
    </build> 
</project> 

什么可能是例外的来源?

+0

请检查您的日食类路径文件。默认情况下,它不包括资源文件夹 – Naresh 2014-02-27 09:07:54

回答

15

正如@JBNizet所说,你的hibernate.cfg.xml应该在src/main/resources中。在src中,它不会被添加到您的类路径中以用于运行时。

如果您在Eclipse中运行项目,请不要忘记在构建路径配置的项目首选项中检查src/main/resources未从您的类路径中排除,并且确实是源文件夹。

+0

谢谢,那帮了我。 – devger 2013-03-06 22:36:06

+0

非常好分析@benzonico。大拇指的答案 – 2016-11-27 04:01:35

8

该文件应该在运行时类路径中。 Maven将src/main/resources下的资源拷贝到target/classes文件夹中。所以你的配置文件应该在那里。

这就是说,你不显示加载文件的代码,所以可能会有其他问题。

+0

不幸的是,这并没有帮助。用Java文件更新我的文章。 – devger 2013-03-06 21:54:54

+0

你可以在目标/类下找到hibernate.cfg.xml文件吗? – 2013-03-06 22:09:54

+0

不,在目标/类下没有hibernate.cfg.xml – devger 2013-03-06 22:15:01

1

您可以使用采用hibernateConfig File参数的configure(File configFile)方法从其他目录(不一定是类路径)加载hibernate.cfg.xml。 (注意,我使用Hibernate 4.3.7)

像这样:


String hibernatePropsFilePath = "/etc/configs/hibernate.cfg.xml"; 
File hibernatePropsFile = new File(hibernatePropsFilePath); 

Configuration configuration = new Configuration(); 
configuration.configure(hibernatePropsFile); 

StandardServiceRegistryBuilder serviceRegistryBuilder = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()); 

ServiceRegistry serviceRegistry = serviceRegistryBuilder.build(); 

SessionFactory sessionFactory = configuration.buildSessionFactory(serviceRegistry); 

0
For the People who are facing this issue while deploying on linux machine 

您需要的hibernate.cfg.xml复制到你的战项目的classes目录。

In Eclipse/Maven Project: (During Development) 

您需要将hibernate.cfg.xml复制到Eclipse/Maven项目的src目录中。

0

如果您正在使用Intellij Idea,请在src \ main \ java下创建一个名为“resources”的文件夹。打开您的项目的模块设置,从左侧选择“Modules”并在“sources”选项卡中选择新创建的“resources”文件夹,并将其标记为“Resources”。 enter image description here

那么这应该工作

Configuration con = new Configuration().configure("hibernate.cfg.xml"); 
相关问题