您的位置:首页 > 编程语言 > Java开发

关于java.lang.IllegalStateException: getOutputStream() has already been called for this response求解

2014-05-29 12:20 471 查看
情况:

控制台打出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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐