成都创新互联网站制作重庆分公司

Hibernate怎么绑定JNDI

这篇文章主要介绍“Hibernate怎么绑定JNDI”,在日常操作中,相信很多人在Hibernate怎么绑定JNDI问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Hibernate怎么绑定JNDI”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联公司2013年至今,先为川汇等服务建站,川汇等地企业,进行企业商务咨询服务。为川汇企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

Hibernate绑定JNDI名称是在net.sf.hibernate.impl.SessionFactoryObjectFactory程序里面实现的,我来分析一下Hibernate绑定JNDI的过程:

我们获得SessionFactory一般是这样写代码:

Configuration conf = new Configuration()。addClass(Cat.class);  SessionFactory sf = conf.buildSessionFactory();

首先是new Configuration()创建一个Configuration,在这个构造器里面进行配置文件(hibernate.properties)的读取工作,然后保存到一个Properties对象里面去,和JNDI相关的是这个属性:

hibernate.session_factory_name hibernate/session_factory

接着调用buildSessionFactory()方法,该方法检查一下配置信息,然后调用SessionFactoryImpl的一个构造器。在构造器里面注意下面两行代码:

name = properties.getProperty(Environment.SESSION_FACTORY_NAME);  SessionFactoryObjectFactory.addInstance(uuid, name, this, properties);

调用了SessionFactoryObjectFactory的addInstance方法,并且把自身(SessionFactory的实例)作为参数传递。***在addInstance方法可以看到如下代码:

Context ctx = NamingHelper.getInitialContext(properties);  NamingHelper.bind(ctx, name, instance);

instance 就是SessionFactory的实例,通过读源代码,可以清楚的看到Hibernate是在conf.buildSessionFactory()的时候通过一系列类方法调用,把创建的SessionFactory实例绑定到配置文件(hibernate.properties)中 hibernate.session_factory_name属性指定的名称上的,因此可见Hibernate绑定JNDI,Hibernate自身是具有动态绑定功能的。但是Hibernate需要获得一个SessionFactory实例用于绑定,而这个SessionFactory实例需要我们写代码进行预先创建,并且必须保证该过程要在所有其它要从JNDI上获得SessionFactory实例的程序之前完成。

因此对于任何App Server来说,我们都不必去管JNDI名称的绑定过程,只需要保证预先创建一个SessionFactory实例出来就够了,剩下的工作 Hibernate会做的。那么如何确保预创建SessionFactory实例呢,如果是Servlet,可以配置一个初始化的Servlet.

Configuration conf = new Configuration()。addClass(Cat.class);  SessionFactory sf = conf.buildSessionFactory();

这样的代码加进去就可以了。如果是包含EJB的的复杂的J2EE应用,可能需要依靠App Server的功能来保证预创建SessionFactory实例。

到此,关于“Hibernate怎么绑定JNDI”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


分享名称:Hibernate怎么绑定JNDI
网站路径:http://cxhlcq.cn/article/goodei.html

其他资讯

在线咨询

微信咨询

电话咨询

028-86922220(工作日)

18980820575(7×24)

提交需求

返回顶部