做第一個hibernate項目運行client端時出現:
06:48:02,578 WARN SessionFactoryObjectFactory:98 - 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:52)
at org.hibernate.impl.SessionFactoryObjectFactory.addInstance(SessionFactoryObjectFactory.java:90)
at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:306)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1218)
at com.lpf.hibernate.Client.main(Client.java:17)
經上網查找,原來是在hibernate.cfg.xml配置文件的<session-factory>標籤中多了 session_factory_name 變量,如圖,如果你設置了這個變量,hibernate會試圖把這個sessionfacotry註冊到jndi中去。
只要刪除這個變量就ok了。
希望對初學hibernate的人有些幫助。