zoukankan      html  css  js  c++  java
  • 【转】WCF传输大数据的设置

    在从客户端向WCF服务端传送较大数据(>65535B)的时候,发现程序直接从Reference的BeginInvoke跳到EndInvoke,没有进入服务端的Service实际逻辑中,怀疑是由于数据过大超出限定导致的。

    问题是我实际发送的数据是刚刚从WCF服务端接收过来的,一来一去,数据量差别并不大。

    然后发现,在客户端和服务端实际使用的是不同的配置,对于客户端,在添加ServiceReference时自动生成的ServiceReferences.ClientConfig文件中system.serviceModel节下有这样的设置:

    <bindings>
        <basicHttpBinding>
            <binding name="BasicHttpBinding_WcfService" maxBufferSize="2147483647"
                maxReceivedMessageSize="2147483647">
                <security mode="None" />
            </binding>
        </basicHttpBinding>
    </bindings>

    然后在Client节里应用Binding Configuration:

    <client>
                <endpoint address="http://localhost:22000/Service/WcfService.svc"
                    binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_WcfService"
                    contract="WcfServiceReference.WcfService" name="BasicHttpBinding_WcfService" />
    </client>

    在Binding里指定了最大缓存字节数和最大接受字节数,相当于2G的大小!除非传一整套连续剧,一般是够用了。

    而在服务端,Web.config文件里,Bindings节是空的,而Service也没有指定bindingConfiguration属性,那么它们采用的就是默认的65535的大小。

    问题找到,解决就比较容易了:

    在Bindings节添加新的Binding设置,指定最大接受数据:

    <bindings>
        <basicHttpBinding>
            <binding name="LargeDataTransferServicesBinding" maxReceivedMessageSize="2147483647"
      messageEncoding="Text" transferMode="Streamed" sendTimeout="00:10:00" />
        </basicHttpBinding>
    </bindings>

    之后给相应的Service指定bindingConfiguration属性:

    <service behaviorConfiguration="Server.Service.WcfServiceBehavior"
      name="Server.Service.WcfService">
      <endpoint address="" binding="basicHttpBinding" bindingConfiguration="LargeDataTransferServicesBinding" contract="Server.Service.WcfService" />
      <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
    </service>

    这样就可以从客户端发送足够大的数据了。

    P.S.:

    .net默认只能传4M的文件,所以尽管设定了Wcf两端的配置,还是超不出.net的限定,所以如果要传输大文件,还需要在System.Web节下加上

        <httpRuntimemaxRequestLength="102400" />
    

    这里的单位是KB,这样就可以传100M的文件了。当然,这么大的文件,最好还是分段传输比较好。

    转:http://www.cnblogs.com/smjack/archive/2009/02/27/1399353.html

    <wsHttpBinding>:http://msdn.microsoft.com/zh-cn/library/ms731299.aspx

  • 相关阅读:
    linux常用命令
    设计模式-软件设计原则1-开闭原则
    java连接redis5.0单机版报连接超时错误
    模拟安装redis5.0集群并通过Java代码访问redis集群
    redis安装-单机版
    eclipse异常关了,tomcat如何关
    java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component...
    排序算法
    RpcException:No provider available for remote service异常
    3.mysql多表
  • 原文地址:https://www.cnblogs.com/springwind268/p/4203327.html
Copyright © 2011-2022 走看看