У меня служба WCF, размещенная на IIS, и я использую wsHttpBinding с TransportWithMessageCredentials. Он работает нормально, но теперь я должен подготовить тот же сервис, размещенный в Windows Service. Я пытаюсь использовать те же настройки - wshttpbinding и TransportWithMessageCredentials.
Я уже добавил такой код в свой конфигурационный файл:
<baseAddresses>
<add baseAddress="https://xxx:9094"/>
<add baseAddress="http://xxx:9095"/>
</baseAddresses>
Я могу получить доступ к сервису через http, но когда я пытаюсь запросить адрес https, я получаю ответ от браузера "Не удалось установить безопасное соединение
Соединение с сервером было сброшено при загрузке страницы.
Запрашиваемая страница не может быть отображена, поскольку подлинность полученных данных не может быть подтверждена. Пожалуйста, сообщите владельцам сайта об этой проблеме. "
Должен ли я сделать что-то дополнительное с моим конфигурационным файлом или это проблема с адресом? Я могу получить сервис через https с портом 9092, который размещен на IIS.
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.serviceModel>
<services>
<service behaviorConfiguration="BasicBehavior" name="xxx">
<endpoint address="" behaviorConfiguration="EndpointBehavior" bindingConfiguration="WSBinding"
binding="wsHttpBinding" name="KeyManager" contract="xxx" />
<endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
<host>
<baseAddresses>
<add baseAddress="https://xxx:9094"/>
<add baseAddress="http://xxx:9095"/>
</baseAddresses>
</host>
</service>
</services>
<bindings>
<basicHttpBinding>
<binding name="BasicBinding" sendTimeout="00:05:00">
<readerQuotas maxStringContentLength="2147483647"/>
<security mode="None"/>
</binding>
</basicHttpBinding>
<wsHttpBinding>
<binding name="WSBinding" sendTimeout="00:05:00" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647">
<readerQuotas maxDepth="2000000" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
<security mode ="TransportWithMessageCredential">
<message clientCredentialType ="UserName"/>
</security>
</binding>
</wsHttpBinding>
</bindings>
<behaviors>
<serviceBehaviors>
<behavior name="BasicBehavior">
<serviceMetadata httpGetEnabled="true"httpsGetEnabled="true"/>
<serviceDebug includeExceptionDetailInFaults="true"/>
<serviceCredentials>
<userNameAuthentication userNamePasswordValidationMode="Custom" customUserNamePasswordValidatorType="Service.ServiceAuthenticator, Service"></userNameAuthentication>
<clientCertificate>
<authentication certificateValidationMode="ChainTrust" revocationMode = "NoCheck" />
</clientCertificate>
</serviceCredentials>
</behavior>
</serviceBehaviors>
<endpointBehaviors>
<behavior name="EndpointBehavior">
</behavior>
</endpointBehaviors>
</behaviors>
</system.serviceModel>
</configuration>