Hibernate第一个事例的javax.naming.NoInitialContextException (转载)

1.如果出现这样的提示,意思是说yourslf4j包的版本不兼容,但是不必管他,这句的具体产生原因,还待高人解答。

SLF4J:Therequestedversion1.6byyourslf4jbindingisnotcompatiblewith[1.5.5,1.5.6,1.5.7,1.5.8]

SLF4J:Seehttp://www.slf4j.org/codes.html#version_mismatchforfurtherdetails.

15[main]INFOorg.hibernate.cfg.Environment-Hibernate3.3.2.GA

31[main]INFOorg.hibernate.cfg.Environment-hibernate.propertiesnotfound

31[main]INFOorg.hibernate.cfg.Environment-Bytecodeprovidername:javassist

2.如果报出如下异常:

1109[main]WARNorg.hibernate.impl.SessionFactoryObjectFactory-CouldnotbindfactorytoJNDI

javax.naming.NoInitialContextException:Needtospecifyclassnameinenvironmentorsystemproperty,orasanappletparameter,orinanapplicationresourcefile:java.naming.factory.initial

atjavax.naming.spi.NamingManager.getInitialContext(UnknownSource)

atjavax.naming.InitialContext.getDefaultInitCtx(UnknownSource)

atjavax.naming.InitialContext.getURLOrDefaultInitCtx(UnknownSource)

atjavax.naming.InitialContext.getNameParser(UnknownSource)

atorg.hibernate.util.NamingHelper.bind(NamingHelper.java:75)

atorg.hibernate.impl.SessionFactoryObjectFactory.addInstance(SessionFactoryObjectFactory.java:113)

atorg.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:348)

atorg.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1341)

atcom.asm.hibernate.test.UserTest.main(UserTest.java:16)

------解决方法--------------------------------------------------------

应该是jndi没有配置好

------解决方法--------------------------------------------------------

配置文件名是不是hibernate.cfg.xml?

代码newConfiguration().configure().buildSessionFactory();是指读入默认名为hibernate.cfg.xml的配置文件。

------解决方法--------------------------------------------------------

<session-factoryname="eheshnew">

改成

<session-factory>

name="xxxx"是为了把SessionFactory的唯一实例bind到jndi上的,这样可以通过newInitialContext().lookup("xxxx")来得到SessionFactory,不过实际上没什么用处。

非j2ee容器下直接执行或容器不支持jndi动态bind(如tomcat)都会出现这个问题。

相关推荐