Как настроить службу WCF с двумя конечными точками, чтобы использовать разные ListenUri для каждой конечной точки? - PullRequest
4 голосов
/ 12 января 2012

У меня есть служба WCF, которая предоставляет конечную точку с помощью webHttpBinding и используется приложениями WPF и ASP.NET. Все отлично работает.

Я сейчас пытаюсь использовать службу из Windows Phone (WP7). Однако, поскольку .NET Framework еще не совсем догнал WP7, пространство имен System.ServiceModel.Web недоступно, в результате чего webHttpBinding не работает в WP7.

Теперь, на моем сервисе, если я переключу webHttpBinding на basicHttpBinding, приложение телефона будет работать.

Я не хочу переделывать мои приложения WPF и ASP.NET, чтобы использовать basicHttpBinding.

Я понимаю, что WCF способен поддерживать несколько привязок, и я попытался настроить и запустить службу так, чтобы она выставляла конечные точки для webHttpBinding и basicHttpBinding. Служба запускается нормально. Однако приложения WPF и ASP.NET не могут получить к нему доступ. И когда я пытаюсь создать ссылку на службу в приложении WP7, я получаю следующее сообщение:

Экземпляр привязки уже был связан для прослушивания URI http://localhost:1726/GeneralService.svc'. Если две конечные точки хотят использовать один и тот же ListenUri, они также должны использовать один и тот же объект привязки пример. Две конфликтующие конечные точки были либо указаны в Вызовы AddServiceEndpoint (), в файле конфигурации или их комбинации AddServiceEndpoint () и config.

Мы с коллегой поиграли с различными изменениями атрибутов baseAddress, address и listenUri без какой-либо удачи. Сейчас мы находимся на стадии проб и ошибок, которые не очень эффективны.

<system.serviceModel>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
    <bindings>
        <basicHttpBinding>
            <binding name="generalBasic" />
        </basicHttpBinding>
        <webHttpBinding>
            <binding name="general" maxReceivedMessageSize="2147483647">
                <readerQuotas maxStringContentLength="2147483647" maxArrayLength="2147483647" />
                <security mode="None">
                    <transport clientCredentialType="None" />
                </security>
            </binding>
        </webHttpBinding>
    </bindings>
    <behaviors>
        <serviceBehaviors>
            <behavior>
                <serviceMetadata httpGetEnabled="true"/>
                <serviceDebug includeExceptionDetailInFaults="false" />
            </behavior>
        </serviceBehaviors>
        <endpointBehaviors>
            <behavior name="web">
                <webHttp />
            </behavior>
        </endpointBehaviors>
    </behaviors>
    <services>
        <service name="MyProject.GeneralService">
            <endpoint address="mex" 
                binding="mexHttpBinding"
                contract="IMetadataExchange" />
            <endpoint address="" 
                binding="basicHttpBinding" 
                bindingConfiguration="generalBasic"
                contract="MyProject.Contracts.IGeneralService" />
            <endpoint behaviorConfiguration="web" 
                binding="webHttpBinding"
                bindingConfiguration="general" 
                contract="MyProject.Contracts.IGeneralService" />
            <host>
                <baseAddresses>
                    <add baseAddress="http://localhost:1726/" />
                </baseAddresses>
            </host>
        </service>
    </services>
</system.serviceModel>

Ответы [ 4 ]

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

Просто укажите атрибут адреса со значением для базовой или конечной точки webhttp, который будет различать его адрес. Пример:

<endpoint behaviorConfiguration="web" address="rest" binding="webHttpBinding" bindingConfiguration="general" contract="MyProject.Contracts.IGeneralService" /> 

должно решить вашу проблему

2 голосов
/ 31 августа 2012

При определении ваших конечных точек для первой вы указываете address="", а для второй у вас нет никакого значения (поэтому даже для этой мы будем иметь адрес как "")

<endpoint address="" 
            binding="basicHttpBinding" 
            bindingConfiguration="generalBasic"
            contract="MyProject.Contracts.IGeneralService" />
        <endpoint behaviorConfiguration="web" 
            binding="webHttpBinding"
            bindingConfiguration="general" 
            contract="MyProject.Contracts.IGeneralService" />

Так что в том случае, когда мы указываем адрес как пустой, он будет использовать базовый адрес по умолчанию.

Поэтому попробуйте указать какое-либо значение для любой из конечных точек. Так что у нас будет другой адрес для этих 2 конечных точек.

<endpoint address="" 
            binding="basicHttpBinding" 
            bindingConfiguration="generalBasic"
            contract="MyProject.Contracts.IGeneralService" />
        <endpoint behaviorConfiguration="web" address="WP7Service" 
            binding="webHttpBinding"
            bindingConfiguration="general" 
            contract="MyProject.Contracts.IGeneralService" />

Итак, наш новый адрес конечной точки:

  1. http://localhost:1726/GeneralService.svc
  2. http://localhost:1726/GeneralService.svc/WP7Service
0 голосов
/ 29 июня 2018

Мне не хватало protocolMapping для обеих конечных точек:

<configuration>
  <!--...-->
  <system.serviceModel>
    <!--...-->
    <protocolMapping>
      <add binding="basicHttpBinding" scheme="http" bindingConfiguration="BasicHttpBindingConfiguration"/>
      <add binding="basicHttpsBinding" scheme="https" bindingConfiguration="SecureHttpBindingConfiguration"/>
    </protocolMapping>
    <bindings>
      <basicHttpBinding>
        <binding name="BasicHttpBindingConfiguration" />
        <binding name="SecureHttpBindingConfiguration" >
          <security mode="Transport">
            <transport clientCredentialType="None" proxyCredentialType="None"/>
          </security>
        </binding>
      </basicHttpBinding>
    </bindings>
    <services>
      <service name="Namespace.ServiceName">
        <endpoint address="" binding="basicHttpBinding" bindingConfiguration="BasicHttpBindingConfiguration"
          contract="Namespace.IServiceName" />
      </service>
      <service name="Namespace.ServiceName">
        <endpoint address="" binding="basicHttpsBinding" bindingConfiguration="BasicHttpsBindingConfiguration"
          contract="Namespace.IServiceName" />
      </service>
    </services>
    <!--...-->
  </system.serviceModel>
  <!--...-->
</configuration>
0 голосов
/ 13 января 2012

Для использования сервиса на WP вы должны предоставить свой сервис с конечными точками Rest, Soap или OData. В приведенной ниже ссылке довольно ясно описано, как предоставить WCF RIA для таких целей:
Предоставление служб WCF (SOAP \ WSDL)
Это прекрасно работает для меня.

...