控制台打出java.lang.IllegalStateException: getOutputStream() has already been called for this response,页面没反应。
使用架构:easyui+sping3 MVC + jpa
页面用easyui-datagrid 查询并展示一个列表。
数据表结构:
order(
orderid
)
order_detail(
orderDetailId,
orderId
)
实体配置:
@Entity
@Table(name="ORDER")
@JsonIgnoreProperties( value={"hibernateLazyInitializer","handler"})
public class OrderBO extends BaseEntity {
@Id
private String orderId;
@OneToOne(targetEntity=OrderDetailBO.class,optional = true,fetch=FetchType.LAZY)
@JoinColumn(name="orderId",insertable=true,updatable=true)
private OrderDetailBO orderDetailBO;
}
@Entity
@Table(name="ORDER_DETAIL")
@JsonIgnoreProperties( value={"hibernateLazyInitializer","handler"})
public class OrderDetailBO extends BaseEntity{
@Id
private String orderDetailId;
private String orderId;
@OneToOne(targetEntity=OrderBO.class,optional = true,fetch=FetchType.LAZY)
@JoinColumn(name="orderId",insertable=true,updatable=true)
private OrderBO orderBO;
}
service层查询hql:
select new map(orderDetailBo as orderDetailBo,orderDetailBo.orderDetailId as uid)
from OrderDetailBO orderDetailBo,OrdersBO ordersBo
where orderDetailBo.orderId = ordersBo.orderId
查询结果Map 返回页面报错java.lang.IllegalStateException: getOutputStream() has already been called for this response
经过反复调试,需要设置orderDetailBo.getOrderBO().setOrderDetailBO(null)可以解决。
为什么会是这样,请高手求解!!!
网上找到的答案:
在web.xml配置
<!--
org.codehaus.jackson.map.JsonMappingException: could not initialize proxy - no Session
org.hibernate.LazyInitializationException: could not initialize proxy - no Session
这种异常有时是因为在用Hibernate的load方法取数据库的数据时发生的,因此往往load出来的对象是一个Proxy即一个代理对象,而取出来的方法执行完毕后,session就会关闭,
而当返回这个代理对象到客户端解析jsp页面时才会真正的发SQL语句,而此时的session已经关闭,因此会抛出此异常。解决方法如下:
(1)使用get方法来替代load方法,但是要注意的时若get方法的数据表若还关联了其他的对象则依然不会在get对象时发出SQL语句,依然会出现这个异常。
(2)扩大session的生命周期。即可采用Spring提供的一个filter:OpenSessionInView。
完整的filter配置如下:
-->
<filter>
<filter-name>OpenSessionInView</filter-name>
<filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>
<async-supported>true</async-supported>
</filter>
<filter-mapping>
<filter-name>OpenSessionInView</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>