问题产生的原因
当我们进行多表查询的时候,连接的表往往会采用延迟加载的策略,我们的事物管理往往会放在Service层,当事物提交Session关闭后,在Action才会用到连接表中的数据,这时候再尝试调用Session,获取数据.但是Session已经关闭了,自然就会报出no session的错误.
如何解决
Spring给出了非常成熟的解决方案
在web.xml中 struts2配置之前配置如下内容,即可解决问题
<filter>
<filter-name>openSessionInView</filter-name>
<filter class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter.class</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/8*</url-pattern>
</filter-mapping>
如果使用的是Spring data 整合JPA的方法进行开发
web.xml配置如下
<filter>
<filter-name>openSessionInView</filter-name>
<filter-class>org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/*</url-pattern>