Поддерживает ли WCF SNI (указание имени сервера)

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

Любая помощь высоко ценится, поскольку я мало знаю о WCF и ничего о SNI.

конфиг

<endpoint 
 address="https://their.server.com/theirservice.svc"
 binding="basicHttpBinding"  
  bindingConfiguration="BasicHttpBinding_ISyncFramework2"
  contract="ISyncFramework" name="BasicHttpBinding_ISyncFramework2">
 </endpoint>

       <basicHttpBinding>
         <binding name="BasicHttpBinding_ISyncFramework2" closeTimeout="00:01:00"
        openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
       allowCookies="false" bypassProxyOnLocal="false" 
      hostNameComparisonMode="StrongWildcard"
      maxBufferSize="65536" maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
      messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered"
      useDefaultWebProxy="true">
           <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
               maxBytesPerRead="4096" maxNameTableCharCount="16384" />
           <security mode="Transport">
             <transport clientCredentialType="Basic" proxyCredentialType="None"
                 realm="" />
           </security>
         </binding>
       </basicHttpBinding>

код:

            var service = new SyncFrameworkClient();
            service.ClientCredentials.UserName.UserName = "username";
            service.ClientCredentials.UserName.Password = "thepassword";

            service.method() // fails!

вызов метода завершается неудачно с:

Запрашиваемая служба https://their.server.com/theirservice.svc не может быть активирована. См. Журналы диагностической трассировки сервера для получения дополнительной информации.

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

Server stack trace: 
   at System.ServiceModel.Channels.HttpChannelUtilities.ValidateRequestReplyResponse(HttpWebRequest request, HttpWebResponse response, HttpChannelFactory factory, WebException responseException, ChannelBinding channelBinding)
   at System.ServiceModel.Channels.HttpChannelFactory.HttpRequestChannel.HttpChannelRequest.WaitForReply(TimeSpan timeout)
   at System.ServiceModel.Channels.RequestChannel.Request(Message message, TimeSpan timeout)
   at System.ServiceModel.Dispatcher.RequestChannelBinder.Request(Message message, TimeSpan timeout)
   at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs, TimeSpan timeout)
   at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs)
   at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall, ProxyOperationRuntime operation)
   at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message)

1 ответ

Решение

Эта ошибка обычно является проблемой на стороне службы, а не на стороне клиента. SNI - это серверная технология для улучшения рукопожатия SSL, и в стеке Microsoft она поддерживается только в неизданной версии IIS 8. Если сторонние разработчики не развернули свой собственный стек SNI/SSL, маловероятно, что их сервис WCF потребует этого.

Что касается фактического исключения, которое вы получаете, похоже, что что-то похожее на это сообщение в блоге, вероятно, будет причиной проблемы. Ваша конфигурация и фрагменты кода выглядят правильно для basicHttpBinding с использованием SSL и базовой HTTP-аутентификации.

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