WCF REST - проблема потоковой передачи с IIS6 - PullRequest
1 голос
/ 04 мая 2011

Я пытаюсь передать файл на сервер с помощью WCF REST. Когда я разместил приложение на консоли, потоковый файл пошел. И.Е. когда я отправлял байты в цикле (читая файл для отправки) и оставлял отладчик на стороне сервера, сервис использовался, чтобы попасть в каждый цикл. Но теперь, когда я разместил службу на IIS 6, служба запускается только при закрытии потока. Это какая-то проблема IIS6 или я делаю что-то не так?

Ниже приводится web.config:

<system.web>
    <compilation debug="true" targetFramework="4.0" />
    <pages validateRequest="false" />
    <httpRuntime  maxRequestLength="102400" executionTimeout="3600" requestValidationMode="2.0" requestPathInvalidCharacters="" />

</system.web>

<system.serviceModel>
    <serviceHostingEnvironment aspNetCompatibilityEnabled="true"/>
    <bindings>
        <webHttpBinding>
            <binding name="streamWebHttpBinding" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647" receiveTimeout="01:00:00" sendTimeout="01:00:00" transferMode="Buffered" />
        </webHttpBinding>
    </bindings>
    <behaviors>
        <serviceBehaviors>
            <behavior name="FileUpload.FileUploadBehavior">
                <serviceMetadata httpGetEnabled="true"/>
                <serviceDebug includeExceptionDetailInFaults="true"/>
            </behavior>
        </serviceBehaviors>
        <endpointBehaviors>
            <behavior name="RestBehavior">
                <webHttp />
            </behavior>
        </endpointBehaviors>
    </behaviors>
    <services>
        <service name="FileUpload.UploadData" behaviorConfiguration="FileUpload.FileUploadBehavior" >
            <endpoint behaviorConfiguration="RestBehavior" address="" contract="FileUpload.IUpload" binding="webHttpBinding" bindingConfiguration="streamWebHttpBinding" />
        </service>
    </services>
</system.serviceModel>

Пожалуйста, помогите

Редактировать:

Plaing код клиента:

HttpWebRequest req = GetWebRequest("asyncfileupload", fileName);
            // 64 KB buffer
            byte[] buf = new byte[0x10000];
            Stream st = req.GetRequestStream();
            int bytesRead;

            using (FileStream fs = new FileStream(filepath, FileMode.Open, FileAccess.Read))
            {
                bytesRead = fs.Read(buf, 0, buf.Length);
                while (bytesRead > 0)
                {
                    st.Write(buf, 0, bytesRead);
                    bytesRead = fs.Read(buf, 0, buf.Length);
                }
                st.Close();
            }

Ошибка происходит в коде "st.Write (buf, 0, bytesRead);" который говорит - Запрос был прерван: Запрос был отменен. через ~ 2 минуты

1 Ответ

1 голос
/ 04 мая 2011

Вы пробовали это?

1) Установите свойство KeepAlive HttpWebRequest для false (есть производительность ударил в постоянно открывающемся и закрытие соединения)

2) Расширьте свойства Timeout: WebRequest.ReadWriteTimeout, WebRequest.Timeout, RequestStream.WriteTimeout и RequestStream.ReadTimeout.

Оригинальный ответ на проблему схожести.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...