System.ServiceModel.CommunicationException: «Произошла ошибка при получении HTTP

У меня есть эта ошибка в моем клиенте. System.ServiceModel.CommunicationException: «Произошла ошибка при получении HTTP-ответа на http://локальный:8099/IService. Это может быть связано с тем, что привязка конечной точки службы не использует протокол HTTP. Это также может быть связано с прерыванием сервером контекста HTTP-запроса (возможно, из-за закрытия службы). См. журналы сервера для более подробной информации.' конфигурация клиента

<?xml version = "1.0" encoding = "utf-8"?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name = "entityFramework" type = "System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission = "false" />
  </configSections>
  <startup>
    <supportedRuntime version = "v4.0" sku = ".NETFramework,Version=v4.6.1" />
  </startup>
  <system.serviceModel>
    <bindings>
      <basicHttpBinding>
        <binding name = "BasicHttpBinding_IProgrammService" />
      </basicHttpBinding>
    </bindings>
    <client>
      <endpoint address = "http://localhost:8099/IService" binding = "basicHttpBinding" bindingConfiguration = "BasicHttpBinding_IProgrammService" contract = "ServiceReferenceMrChicken.IProgrammService" name = "BasicHttpBinding_IProgrammService" />
    </client>
  </system.serviceModel>
  <entityFramework>
    <defaultConnectionFactory type = "System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
      <parameters>
        <parameter value = "v14.0" />
      </parameters>
    </defaultConnectionFactory>
    <providers>
      <provider invariantName = "System.Data.SqlClient" type = "System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
    </providers>
  </entityFramework>
  <connectionStrings>
    <add name = "EmployeeConnection" connectionString = "Data Source=den1.mssql7.gear.host;Initial Catalog=mrchikendb;User ID=mrchikendb;Password=Qwer-12" providerName = "System.Data.SqlClient" />
  </connectionStrings>
</configuration>

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

<?xml version = "1.0" encoding = "utf-8"?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name = "entityFramework" type = "System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission = "false" />
  </configSections>
  <startup>
    <supportedRuntime version = "v4.0" sku = ".NETFramework,Version=v4.6.1" />
  </startup>
  <system.serviceModel>
    <bindings />
    <client />
    <services>
      <service name = "IService.ProgrammService" behaviorConfiguration = "mexBehavior">
        <endpoint address = "IService" binding = "basicHttpBinding" contract = "IService.IProgrammService"></endpoint>
        <endpoint address = "mex" binding = "mexHttpBinding" contract = "IMetadataExchange"></endpoint>
        <host>
          <baseAddresses>
            <add baseAddress = "http://localhost:8099/" />
          </baseAddresses>
        </host>
      </service>
    </services>
    <behaviors>
      <serviceBehaviors>
        <behavior name = "mexBehavior">
          <dataContractSerializer maxItemsInObjectGraph = "2147483646"/>
          <serviceThrottling maxConcurrentCalls = "120" maxConcurrentSessions = "120"
                             maxConcurrentInstances = "120" />
          <serviceMetadata httpGetEnabled = "true" />
          <serviceDebug includeExceptionDetailInFaults = "true" />
        </behavior>
      </serviceBehaviors>
    </behaviors>
  </system.serviceModel>
  <entityFramework>
    <defaultConnectionFactory type = "System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
      <parameters>
        <parameter value = "v14.0" />
      </parameters>
    </defaultConnectionFactory>
    <providers>
      <provider invariantName = "System.Data.SqlClient" type = "System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
    </providers>
  </entityFramework>
  <connectionStrings>
    <add name = "EmployeeConnection" connectionString = "Data Source=den1.mssql7.gear.host;Initial Catalog=mrchikendb;User ID=mrchikendb;Password=Qwer-12" providerName = "System.Data.SqlClient" />
  </connectionStrings>
  <system.diagnostics>
    <sources>
      <source name = "System.ServiceModel" switchValue = "Information, ActivityTracing" propagateActivity = "true">
        <listeners>
          <add name = "traceListener" type = "System.Diagnostics.XmlWriterTraceListener" initializeData = "C:\TracesServ_ce.svclog" />
        </listeners>
      </source>
    </sources>
  </system.diagnostics>
</configuration>

код, где я дал свое исключение

ServiceReferenceMrChicken.ProgrammServiceClient client = new ServiceReferenceMrChicken.ProgrammServiceClient();
            var users = client.GetUsers();
            dataGrid.ItemsSource = users;

код, где я дал свое исключение

ServiceReferenceMrChicken.ProgrammServiceClient client = new ServiceReferenceMrChicken.ProgrammServiceClient();
            var users = client.GetUsers();
            dataGrid.ItemsSource = users;
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
841
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Что-то может быть не так в процессе размещения службы, как мне кажется, ваша конфигурация. Вы можете проверить, правильно ли он размещен, обратившись к WSDL службы.

http://x.x.x.x:8009/service1.svc?wsdl

Как правило, адрес конечной точки службы предоставляется привязками сайта IIS вместо базового адреса файла конфигурации службы, поскольку служба WCF также размещается IIS как веб-сайт. Поэтому следующие фрагменты кода не нужны.

   <host>
      <baseAddresses>
        <add baseAddress = "http://localhost:8099/" />
      </baseAddresses>
    </host>

Между тем, мы должны указать базовый адрес http в модуле привязки сайта IIS.
Тогда адрес службы будет http://x.x.x.x:9001/service1.svc, мы можем ввести базовый адрес службы, чтобы использовать его на стороне клиента с помощью мастера добавления ссылки на службу.
Не стесняйтесь, дайте мне знать, если я могу чем-то помочь.

Если ответ полезен, отметьте его как полезный, чтобы тот, кто столкнется с похожей проблемой, захотел его прочитать.

Abraham Qian 03.05.2019 05:17

Другие вопросы по теме