Невозможно прочитать данные из транспортного соединения: существующее соединение было принудительно закрыто удаленным хостом - PullRequest
1 голос
/ 13 января 2012

Когда я передаю файл размером около 50 Мб по HTTP иногда , я получаю эту ошибку:

Невозможно прочитать данные из транспортного соединения: существующее соединение было принудительно закрытоудаленный хост.

Прежде всего, я не смог найти никакого решения под http://stackoverflow.com.

Есть какие-нибудь подсказки, что я должен улучшить / изменить?

app.config:

 <bindings>
      <basicHttpBinding>
        <binding name="BasicHttpBinding_MyDomainServicesoap" closeTimeout="00:03:00" openTimeout="00:04:00" receiveTimeout="00:10:00" sendTimeout="00:05:00" allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard" maxBufferSize="50000000" maxBufferPoolSize="50000000" maxReceivedMessageSize="50000000" messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered" useDefaultWebProxy="true">
          <readerQuotas maxDepth="64" maxStringContentLength="16384" maxArrayLength="32768" maxBytesPerRead="8192" maxNameTableCharCount="16384"/>
          <security mode="None">
            <transport clientCredentialType="None" proxyCredentialType="None" realm=""/>
            <message clientCredentialType="UserName" algorithmSuite="Default"/>
          </security>
        </binding>
        <binding name="BasicHttpBinding_MyAuthenticationDomainServicesoap" closeTimeout="00:03:00" openTimeout="00:04:00" receiveTimeout="00:10:00" sendTimeout="00:05:00" allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard" maxBufferSize="50000000" maxBufferPoolSize="50000000" maxReceivedMessageSize="50000000" messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered" useDefaultWebProxy="true">
          <readerQuotas maxDepth="64" maxStringContentLength="16384" maxArrayLength="32768" maxBytesPerRead="8192" maxNameTableCharCount="16384"/>
          <security mode="None">
            <transport clientCredentialType="None" proxyCredentialType="None" realm=""/>
            <message clientCredentialType="UserName" algorithmSuite="Default"/>
          </security>
        </binding>
      </basicHttpBinding>
    </bindings>

код:

private void FinishWebRequest(IAsyncResult result)
        {
            // Assign values to these objects here so that they can be referenced in the finally block
            Stream remoteStream = null;
            Stream localStream = null;
            WebResponse response = null;

            try
            {
                response = request.EndGetResponse(result);

              if (response != null)
                {
                    // Once the WebResponse object has been retrieved, get the stream object associated with the response's data
                    remoteStream = response.GetResponseStream();

                    // Create the local file
                    string pathToSaveFile = Path.Combine(FileManager.GetFolderContent(), FileView.Filename);
                    localStream = File.Create(pathToSaveFile);

                    WinAPI.SYSTEM_INFO sysinfo = new WinAPI.SYSTEM_INFO();
                    WinAPI.GetSystemInfo(ref sysinfo);

                    // Allocate a buffer 
                    byte[] buffer = new byte[int.Parse(sysinfo.dwPageSize.ToString())];     
                    int bytesRead;

                    // Simple do/while loop to read from stream until no bytes are returned
                    do
                    {
                        // Read data (up to 1k) from the stream
                        bytesRead = remoteStream.Read(buffer, 0, buffer.Length);

                        // Write the data to the local file
                        localStream.Write(buffer, 0, bytesRead);

                        // Increment total bytes processed
                        BytesProcessed += bytesRead;
                    } while (bytesRead > 0);

                    FileView.Downloaded = DateTime.Now;

                    if (BytesProcessed > 0)
                    {
                        FileView.IsSuccess = true;
                        FileView.IsDownloading = false;
                    }
                    else
                    {
                        FileView.IsSuccess = false;
                        FileView.IsDownloading = false;
                    }
                } 
            }
            catch (Exception ex)
            {
                #region Error
                LogEntry l = new LogEntry();
                l.Message = string.Format("{0}", ex.Message);
                l.Title = "FinishWebRequest() Error";
                l.Categories.Add(Category.General);
                l.Priority = Priority.Highest;

                if (ex.InnerException != null) l.ExtendedProperties.Add("InnerException", ex.InnerException.Message);

                CustomLogger.CustomLogger.WriteErrorLog(l);
                #endregion
            }
            finally
            {
                // Close the response and streams objects here to make sure they're closed even if an exception is thrown at some point
                if (response != null) response.Close();
                if (remoteStream != null) remoteStream.Close();
                if (localStream != null) localStream.Close();
            }
        }

Ответы [ 2 ]

2 голосов
/ 13 января 2012

Я не уверен, что это решение для всех случаев.

Но когда я уменьшил количество параллельных подключений к серверу для загрузки больших файлов только с 3 до 2, ошибки не было.

(Ранее я использовал 3 параллельных соединения.)

1 голос
/ 18 апреля 2012

Я столкнулся с подобной проблемой и смог ее решить, добавив в свой файл web.config раздел о поведении, который указывает сериализатору контракта данных переопределять ограничение размера по умолчанию в 64 КБ.После добавления в конфигурацию я начал получать ошибку на стороне клиента, которая была той же самой проблемой, вам нужно будет добавить эту конфигурацию как на вашу службу, так и на сторону клиента.

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