关于java.lang.IllegalStateException: getOutputStream() has already been called for this response求解
发布日期:2021-06-28 18:26:50 浏览次数:4 分类:技术文章

本文共 2161 字,大约阅读时间需要 7 分钟。

情况:
控制台打出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>

转载地址:https://blog.csdn.net/xjj1314/article/details/27514669 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:oracle 10.2.0.1.0 误删除数据文件 后的处理方法
下一篇:git 终端显示中文乱码

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月08日 13时29分49秒