Ошибка службы WCF: Сведения об исключении: System.Net.WebException: удаленный сервер возвратил ошибку: (400) Неверный запрос
Я создал веб-сервис для загрузки файлов через 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>
Вот ошибка, которую я получаю;
Удаленный сервер возвратил ошибку: (400) Bad Request.
Описание: во время выполнения текущего веб-запроса произошло необработанное исключение. Пожалуйста, просмотрите трассировку стека для получения дополнительной информации об ошибке и о том, где она возникла в коде.
Сведения об исключении: System.Net.WebException: удаленный сервер возвратил ошибку: (400) неверный запрос.
Ошибка источника:
Строка 120:
[System.ComponentModel.EditorBrowsableAttribute (System.ComponentModel.EditorBrowsableState.Advanced)] Строка 121:
FileUploadWcfServiceClient.TransferService.UploadFileResponse FileUploadWcfServiceClient.TransferService.ITransferService.UploadFile (Запрос FileUploadWcfServiceClient.TransferService.RemoteFileInfo); Строка 123: } Строка 124:Исходный файл: C:\Apps\FileUploadWcfService\FileUploadWcfServiceClient\ Сервисные ссылки \TransferService\Reference.cs Строка: 122
Трассировки стека:
[WebException: удаленный сервер возвратил ошибку: (400) неверный запрос.] System.Net.HttpWebRequest.GetResponse () +6111059
System.ServiceModel.Channels.HttpChannelRequest.WaitForReply (TimeSpan timeout) +48[ProtocolException: удаленный сервер возвратил неожиданный ответ: (400) неверный запрос.]
System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage (IMessage 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 \ ServiceUp \
FileUploadWcfServiceClient.Default.Button1_Click(отправитель объекта, EventArgs e) в C:\Apps\FileUploadWcfService\FileUploadWcfServiceClient\Default.aspx.cs:85 System.Web.UI.WebControls.Button.OnClick + событие (8)
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 (логическое значение includeStagesBeforeAsyncPoint, логическое значение includeStagesAfterAsyncPoint) +5563Информация о версии: Microsoft .NET Framework Версия:4.0.30319; ASP.NET версия:4.0.30319.225
Файл, который я пытаюсь загрузить, имеет размер 217 КБ, поэтому я предполагаю, что размер файла здесь не является проблемой.
Как вы думаете, что вызвало ошибку?