ZFYCH_Love

Simply but Powerful

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

今天遇到了一个很牛X的问题,多人一起解决很久,无果。

然,锲而不舍,一下午,从网络海洋里捞啊捞,终于觅得善果。

感谢这位大神,原文地址:http://hi.baidu.com/_253/blog/item/923a83f45b3c37c5f3d38559.html

本文经过了些微的整理。

WCF 传输大量数据出现“基础连接已经关闭...”错误的解决方案

按图做,如果自己的webconfig里没有相应节点,加上就好了。

先说错误:

 WCF服务端配置文件:
客户端
<system.serviceModel>节点下面:

  <behaviors>

    <endpointBehaviors>

      <behavior  >

        <dataContractSerializer maxItemsInObjectGraph="100000000"  />

      </behavior>

    </endpointBehaviors> s

</behaviors>

经过这三步设置,最后就OK了。
 s
 
maxItemsInObjectGraph:一个整数,指定要序列化或反序列化的最大项数,可以限制对象图中要序列化的项数。

MaxItemsInObjectGraph 属性指定序列化程序在一次 ReadObjectWriteObject 方法调用中序列化或反序列化的对象的最大数目。该方法总是读取一个根对象,但此对象的数据成员中可以具有其他对象。这些对象又可以具有其他对象。默认值为 MaxValue。请注意,当序列化或反序列化数组时,每个数组项都计为一个单独的对象

具体分析错误原因:

这个是错误提示,在用WebService序列化的过程中,序列化的对象个数超出了65535个,也就是maxItemsInObjectGraph的默认这,造成这用情况是因为客户端与WebService之间传递的是对象,而WebService每次都要序列化对象,所以对序列化的对象的个数是有限制的,默认的就是65535,这个对象的个数是怎么计算出来的呢?

例如:现在在WebService端有一个对象Student

Public class Student

{ Public int ID{get;set;}

public Name{get;set;}

}

在传递的过程中,对象的个数就是这个对象的本身加上本身所包含的对象的个数,就这个来说那么就是3个对象,要想使这三个对象能够序列化 maxItemsInObjectGraph=对象个数+2(假设maxItemsInObjectGraph默认值为0),只有在maxitemslnObjectGraph 比对象个数+2大的情况下,编译器才不会报错,要不然,就会出现上面的错误,其实还不止于此,这个的前提是只有一条记录的情况下,如果是两条记录呢,MaxItemSlnObjectGraph的最小值=对象个数*记录的条数(传递的可能是这个对象的一个集合)+2,也就是传递的数据越多,MaxItemSlnObjectGraph的值就会越大,当超过他的默认值(65536)的时候就会出现上面的错误了.

 

 

posted on 2012-02-22 17:49  xiaoyang_  阅读(313)  评论(0编辑  收藏  举报