Служба Windows WCF с TransportWithMessageCredentials - PullRequest
0 голосов
/ 18 января 2019

У меня служба 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>
...