博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于java.lang.IllegalStateException: getOutputStream() has already been called for this response求解
阅读量:1825 次
发布时间:2019-04-25

本文共 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>

转载地址:http://ymikf.baihongyu.com/

你可能感兴趣的文章
深度探索MySQL主从复制原理
查看>>
关于Mysql的存储引擎Innodb和Myisam
查看>>
部标JT808协议处理方案
查看>>
WebSocket实现与原理
查看>>
Docker概述与安装使用
查看>>
Java Serializable:明明就一个空的接口嘛
查看>>
Dockerfile 文件命令详解
查看>>
JAVA音视频解决方案----JTT1078-2016文档梳理与一些难点梳理
查看>>
RabbitMQ的工作流程
查看>>
RabbitMQ的消息安全机制
查看>>
Kafka的消息安全机制
查看>>
RabbitMq集群环境搭建
查看>>
系统设计规范化解决了什么问题
查看>>
java:快速排序算法与冒泡排序算法
查看>>
概要设计与详细设计
查看>>
Flying Saucer实现html转pdf(一些问题,持续更新)
查看>>
数据库隔离级别
查看>>
过滤器,拦截器适用场合
查看>>
web 前端入坑第一篇:web前端到底是什么?有前途吗
查看>>
动态代理GOF模式
查看>>