WCF Загрузка 50 мг файла с использованием MTOM - PullRequest
1 голос
/ 06 марта 2012

Каков наилучший способ загрузки с использованием WCF файла 50MG?

Я думал, что MTOM позаботится об этом автоматически.
Думаю, я ошибался ...

исключение происходит даже при работе на LocalHost
(я предполагаю, что использование внешнего IIS будет еще хуже).

Сообщение об исключении:

"Ошибка при получении ответа HTTP на http://localhost:7064/DataSyncService.svc. Это может быть связано с тем, что привязка конечной точки службы не использует протокол HTTP.Это также может быть связано с тем, что сервер прерывает контекст HTTP-запроса (возможно, из-за остановки службы). Дополнительные сведения см. в журналах сервера. "

Конфигурация сервера :

    <system.serviceModel>
    <client>
        <remove contract="IMetadataExchange" name="sb" />
    </client>
    <bindings>
        <wsHttpBinding>
            <binding name="DataSyncBinding" messageEncoding="Mtom" maxReceivedMessageSize ="50000000" maxBufferPoolSize="50000000">
                <readerQuotas maxArrayLength="50000000" />
                <security mode="None" />
            </binding>
        </wsHttpBinding>
    </bindings>
    <services>
        <service behaviorConfiguration="Server.DataSyncServiceBehavior" name="Server.DataSyncService">
            <endpoint address="" binding="wsHttpBinding" bindingConfiguration="DataSyncBinding" name="DataSyncService"
                      contract="Server.IDataSyncService" />
            <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
        </service>
    </services>
    <behaviors>
        <serviceBehaviors>
            <behavior name="Server.DataSyncServiceBehavior">
                <serviceMetadata httpGetEnabled="true" />
                <serviceDebug includeExceptionDetailInFaults="false" />
            </behavior>
        </serviceBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="false" />
</system.serviceModel>

Конфиг клиента :

    <system.serviceModel>
    <bindings>
        <wsHttpBinding>
            <binding name="DataSyncService" closeTimeout="00:05:00" openTimeout="00:05:00"
                receiveTimeout="00:30:00" sendTimeout="00:30:00" bypassProxyOnLocal="false"
                transactionFlow="false" hostNameComparisonMode="StrongWildcard"
                maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
                messageEncoding="Mtom" textEncoding="utf-8" useDefaultWebProxy="true"
                allowCookies="false">
                <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
                    maxBytesPerRead="4096" maxNameTableCharCount="16384" />
                <reliableSession ordered="true" inactivityTimeout="00:10:00"
                    enabled="false" />
                <security mode="None">
                    <transport clientCredentialType="Windows" proxyCredentialType="None"
                        realm="" />
                    <message clientCredentialType="Windows" negotiateServiceCredential="true" />
                </security>
            </binding>
        </wsHttpBinding>
    </bindings>
    <client>
        <endpoint address="http://localhost:7064/DataSyncService.svc"
            binding="wsHttpBinding" bindingConfiguration="DataSyncService"
            contract="DataSyncServiceReference.IDataSyncService" name="DataSyncService" />
    </client>
</system.serviceModel>

Спасибо заранее.

1 Ответ

2 голосов
/ 06 марта 2012

Если файл точно 50 МБ, то ваши maxReceivedMessageSize и maxArrayLength установлены слишком низкими, поскольку 50 МБ на самом деле составляют 50 *1024* 1024 = 52428800 байт. Кроме того, maxReceivedMessageSIze должен учитывать структуру самого сообщения (конверт SOAP и т. Д.), А не только данные.

Вы можете использовать потоковую передачу, это рекомендуемый способ для больших файлов. К сожалению, это не доступно с wsHttpBinding, вам может понадобиться что-то вроде basicHttpBinding или webHttpBinding, чтобы включить потоковую передачу.

Подробнее о потоковой передаче здесь:

http://msdn.microsoft.com/en-us/library/ms733742.aspx

...