Подтвердить что ты не робот

Развертывание службы WCF с привязками и конечными точками HTTP и https

Я написал веб-службу WCF для использования приложения Silverlight. Первоначально услуге требовалось только базовое связывание http. Теперь нам нужно иметь возможность развертывать службу для использования как с http, так и с https. Я нашел некоторые настройки для web.config, которые позволяют мне сделать это следующим образом:

<system.serviceModel>
  <behaviors>
    <endpointBehaviors>
      <behavior name="SilverlightFaultBehavior">
        <silverlightFaults />
      </behavior>
    </endpointBehaviors>
    <serviceBehaviors>
      <behavior name="CxtMappingWebService.CxtMappingWebServiceBehavior">
        <serviceMetadata httpGetEnabled="true" httpsGetEnabled="true" />
        <serviceDebug includeExceptionDetailInFaults="True" />
      </behavior>
    </serviceBehaviors>
  </behaviors>
  <bindings>
    <basicHttpBinding>
      <binding name="SecureHttpBinding">
        <security mode="Transport" />
      </binding>
      <binding name="BasicHttpBinding">
        <security mode="None" />
      </binding>
    </basicHttpBinding>
  </bindings>
  <services>
    <service name="CxtMappingWebService.CxtMappingWebService" behaviorConfiguration="CxtMappingWebService.CxtMappingWebServiceBehavior">
      <endpoint address="" bindingConfiguration="SecureHttpBinding" binding="basicHttpBinding" contract="CxtMappingWebService.ICxtMappingWebService" behaviorConfiguration="SilverlightFaultBehavior" />
      <endpoint address="" bindingConfiguration="BasicHttpBinding" binding="basicHttpBinding" contract="CxtMappingWebService.ICxtMappingWebService" behaviorConfiguration="SilverlightFaultBehavior" />
      <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
    </service>
  </services>
</system.serviceModel>

К сожалению, есть проблема с этим.

Этот веб-сервис должен быть развернут на сотни серверов наших клиентов, и не все из них будут использовать https. Развертывание его на сервере, у которого нет привязки https, установленного в IIS, приводит к сбою. Есть ли способ иметь обе эти привязки в файле web.config по умолчанию, если он не умирает, если в IIS нет привязки https?

У нас есть возможное решение этой проблемы, но это не очень хорошо соответствует нашим требованиям к развертыванию.

Кто-нибудь еще сталкивался с чем-то подобным раньше, и как вы его разрешили?

4b9b3361

Ответ 1

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

            <service name="CxtMappingWebService.CxtMappingWebService" behaviorConfiguration="CxtMappingWebService.CxtMappingWebServiceBehavior">
              <endpoint address="" bindingConfiguration="SecureHttpBinding" binding="basicHttpBinding" contract="CxtMappingWebService.ICxtMappingWebService" behaviorConfiguration="SilverlightFaultBehavior" />
              <endpoint address="" bindingConfiguration="BasicHttpBinding" binding="basicHttpBinding" contract="CxtMappingWebService.ICxtMappingWebService" behaviorConfiguration="SilverlightFaultBehavior" />
              <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
            </service>

Это сработало для меня отлично!

Ответ 2

В конце концов, мы решили пойти с внешними файлами, используя атрибут configSource для разделов привязок, поведения и сервисов web.config, например:

<bindings configSource="bindings.config" />
<behaviors configSource="behaviors.config" />
<services configSource="services.config" />

Таким образом, мы развертываем его по умолчанию с теми внешними файлами, которые настроены только для доступа к http, и дают инструкции (или помогают им) о том, как редактировать внешние файлы для настройки доступа https. Это также позволяет нам развертывать будущие изменения в самом web.config, не перезаписывая внешние файлы конфигурации.

Ответ 3

Это будет обрабатываться установщиком, который вы используете для развертывания службы. Это должно быть предварительным условием (или, по крайней мере, оставить опцию в установщике) для развертывания обеих конечных точек или только http.

Ответ 4

Два из ваших конечных точек имеют один и тот же URI. Это не разрешено в WCF. Вы должны иметь возможность указывать конечные точки с различными привязками, но URI должен быть другим (т.е. Другим номером порта или другим контрактом).