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)都会出现这个问题。