Ошибка службы WCF: Сведения об исключении: System.Net.WebException: удаленный сервер возвратил ошибку: (400) Неверный запрос - PullRequest
0 голосов
/ 28 июля 2011

Я создал веб-сервис для загрузки файлов через http, но с первой попытки он не работает.

Моя веб-служба работает на IIS 7 моего локального компьютера в ASP.NET 4 Integrated App Pool. Вот это мой web-сервис web.config;

<?xml version="1.0"?>
<configuration>

  <system.web>
    <compilation debug="true" targetFramework="4.0" />
  </system.web>

  <system.serviceModel>

    <behaviors>

      <serviceBehaviors>

        <behavior>
          <!-- To avoid disclosing metadata information, set the value below to false and remove the metadata endpoint above before deployment -->
          <serviceMetadata httpGetEnabled="true"/>
          <!-- To receive exception details in faults for debugging purposes, set the value below to true.  Set to false before deployment to avoid disclosing exception information -->
          <serviceDebug includeExceptionDetailInFaults="false"/>
        </behavior>

        <behavior name="TransferServiceBehavior">
          <dataContractSerializer maxItemsInObjectGraph="2147483647" />
          <serviceThrottling maxConcurrentCalls="500"
                             maxConcurrentSessions="500" maxConcurrentInstances="500" />  
        </behavior>

      </serviceBehaviors>

    </behaviors>

    <bindings>
      <basicHttpBinding>
        <binding name="TransferService" maxReceivedMessageSize="2147483647"
                 maxBufferSize="2147483647" transferMode="Streamed">
          <readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647" 
                        maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
          <security mode="None">
            <transport clientCredentialType="None" />
          </security>
        </binding>
      </basicHttpBinding>
    </bindings>

    <services>

      <service behaviorConfiguration="TransferServiceBehavior" name="TransferService">
        <endpoint address="" binding="basicHttpBinding" bindingConfiguration="TransferService"
                contract ="ITransferService">
        </endpoint>
      </service>

    </services>

    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" aspNetCompatibilityEnabled="true" />

  </system.serviceModel>

 <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
  </system.webServer>

  <system.web>
    <!--<httpRuntime maxRequestLength="2097151" />-->
    <httpRuntime maxRequestLength="2097151" 
                 useFullyQualifiedRedirectUrl="true" executionTimeout="14400"   />
  </system.web>

</configuration>

Это файл web.config клиента;

<configuration>
    <system.web>
        <compilation debug="true" targetFramework="4.0" />
        <httpRuntime maxRequestLength="2097150" />
    </system.web>

    <system.serviceModel>

        <bindings>
            <basicHttpBinding>
              <binding name="BasicHttpBinding_ITransferService" closeTimeout="04:01:00"
                  openTimeout="04:01:00" receiveTimeout="04:10:00" sendTimeout="04:01:00"
                  allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"
                  maxBufferSize="2147483647" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647"
                  messageEncoding="Text" textEncoding="utf-8" transferMode="Streamed"
                  useDefaultWebProxy="true">
                <readerQuotas maxDepth="128" maxStringContentLength="2147483647" maxArrayLength="2147483647"
                    maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
                <security mode="None">
                  <transport clientCredentialType="None" proxyCredentialType="None"
                      realm="" />
                  <message clientCredentialType="UserName" algorithmSuite="Default" />
                </security>
              </binding>
            </basicHttpBinding>
        </bindings>

        <client>
            <endpoint address="http://localhost:81/TransferService.svc" binding="basicHttpBinding"
                bindingConfiguration="BasicHttpBinding_ITransferService" contract="TransferService.ITransferService"
                name="BasicHttpBinding_ITransferService" />
        </client>

    </system.serviceModel>
</configuration>

Вот ошибка, которую я получаю;

* * 1010

Удаленный сервер возвратил ошибку: (400) Неверный запрос.

Описание: необработанное исключение произошло во время выполнения текущий веб-запрос. Пожалуйста, просмотрите трассировку стека для более информация об ошибке и ее возникновении в коде.

Сведения об исключении: System.Net.WebException: удаленный сервер возвращен ошибка: (400) неверный запрос.

Ошибка источника:

Строка 120:
[System.ComponentModel.EditorBrowsableAttribute (System.ComponentModel.EditorBrowsableState.Advanced)] Строка 121:
FileUploadWcfServiceClient.TransferService.UploadFileResponse FileUploadWcfServiceClient.TransferService.ITransferService.UploadFile (FileUploadWcfServiceClient.TransferService.RemoteFileInfo запрос) {Строка 122: возврат base.Channel.UploadFile (запрос); Строка 123:} Строка 124:

Исходный файл: C: \ Apps \ FileUploadWcfService \ FileUploadWcfServiceClient \ Service Ссылки \ TransferService \ Reference.cs Строка: 122

Трассировка стека:

[WebException: удаленный сервер возвратил ошибку: (400) Bad Запрос.] System.Net.HttpWebRequest.GetResponse () + 6111059
System.ServiceModel.Channels.HttpChannelRequest.WaitForReply (TimeSpan тайм-аут) + 48

[ProtocolException: удаленный сервер возвратил неожиданный ответ: (400) Неверный запрос.]
System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage (Шеззаде reqMsg, IMessage retMsg) + 9456095
System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke (MessageData & msgData, тип Int32) + 345
FileUploadWcfServiceClient.TransferService.ITransferService.UploadFile (RemoteFileInfo запрос) + 0
FileUploadWcfServiceClient.TransferService.TransferServiceClient.FileUploadWcfServiceClient.TransferService.ITransferService.UploadFile (RemoteFileInfo запрос) в C: \ Apps \ FileUploadWcfService \ FileUploadWcfServiceClient \ Service Ссылки \ TransferService \ Reference.cs: 122
FileUploadWcfServiceClient.Default.Button1_Click (Отправитель объекта, EventArgs e) в C: \ Apps \ FileUploadWcfService \ FileUploadWcfServiceClient \ Default.aspx.cs: 85 System.Web.UI.WebControls.Button.OnClick (EventArgs e) + 118
System.Web.UI.WebControls.Button.RaisePostBackEvent (String eventArgument) + 112
System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent (String eventArgument) + 10
System.Web.UI.Page.RaisePostBackEvent (IPostBackEventHandler sourceControl, String eventArgument) + 13
System.Web.UI.Page.RaisePostBackEvent (NameValueCollection postData) +36 System.Web.UI.Page.ProcessRequestMain (Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) + 5563

Информация о версии: Microsoft .NET Framework Версия: 4.0.30319; ASP.NET версия: 4.0.30319.225

Файл, который я пытаюсь загрузить, имеет размер 217 КБ, поэтому я предполагаю, что размер файла здесь не является проблемой.

Как вы думаете, что вызвало ошибку?

...