N久没用Hibernate了,今天准备熟悉熟悉,就遇到了这个问题,记录下来,方便以后查阅
INFO NamingHelper:49 - JNDI InitialContext properties:{}
WARN SessionFactoryObjectFactory:121 - Could not bind factory to JNDI
javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial
at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:645)
at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:288)
at javax.naming.InitialContext.getURLOrDefaultInitCtx(InitialContext.java:325)
at javax.naming.InitialContext.getNameParser(InitialContext.java:480)
at org.hibernate.util.NamingHelper.bind(NamingHelper.java:75)
at org.hibernate.impl.SessionFactoryObjectFactory.addInstance(SessionFactoryObjectFactory.java:113)
at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:348)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1341)
at com.nw.dao.StudentsDao.main(StudentsDao.java:13)
hibernate.cfg.xml配置如下
<?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 name="mysql">
<!--配置数据库相关信息-->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password"></property>
<!--配置数据库方言-->
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!--是否显示sql-->
<property name="show_sql">true</property>
<mapping resource="com/nw/vo/Students.hbm.xml"/>
</session-factory>
</hibernate-configuration>
考虑到根本就没用到JNDI,怎么会出现这个异常呢,最后在配置文件里发现<session-factory name="mysql">,多了个name="mysql",Hibernate试图将这个sessionFacoty注册到JNDI中,去掉name,异样解除