Ответ 1
Я думаю, вы почти близки к решению. Я попытался воспроизвести вашу проблему, и вот как я подошел.
- Добавьте и установите для httpsGetEnabled значение true в вашем ServiceMetadata. Обмен метаданных произойдет в HTTPS:
<serviceMetadata httpGetEnabled="True" httpsGetEnabled="True" />
- Изменить mexHttpBinding на mexHttpsBinding:
<endpoint address="mex" binding="mexHttpsBinding" contract="IMetadataExchange"/>
- В вашей привязке добавьте следующее:
<netHttpBinding> <binding name="netHttpBinding"> <security mode="TransportWithMessageCredential"> <message clientCredentialType="UserName"/> </security> </binding> </netHttpBinding>
- Так как netHttpBinding использовал http по умолчанию, нам нужно некоторое сопоставление.
<protocolMapping> <add scheme="https" binding="netHttpBinding"/> </protocolMapping>
- По какой-то причине даже я изменяю протоколMapping для использования HTTPS для netHttpBinding, я все еще получаю сообщение об ошибке "Не удалось найти базовый адрес, соответствующий схеме https для конечной точки с привязкой NetHttpBinding. HTTP]." .
Итак, что я сделал, я добавил адрес под моей службой следующим образом:
<host> <baseAddresses> <add baseAddress="https://localhost/Services/"/> </baseAddresses> </host>
Вы можете избежать пятого шага, если вы не заметили сообщение об ошибке, выделенное выше. Я просто поставлю его здесь на случай.
Примечание. Я установил свой сертификат в хранилище сертификатов в Личном кабинете и в доверенном корневом сертификате. Этот пример работает только на одном компьютере, так как имя моего сертификата - только localhost. Кстати, я использовал .NET Framework 4.5 здесь.
Ниже приведена моя полная конфигурация:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.serviceModel>
<services>
<service name="WcfServiceLibrary1.Service1" behaviorConfiguration="ServiceBehavior">
<host>
<baseAddresses>
<add baseAddress="https://localhost/Services/"/>
</baseAddresses>
</host>
<endpoint address="" binding="netHttpBinding" bindingConfiguration="netHttpBinding" contract="WcfServiceLibrary1.IService1" name="WcfServiceLibrary1.IService1"/>
<endpoint address="mex" binding="mexHttpsBinding" contract="IMetadataExchange" listenUriMode="Explicit" />
</service>
</services>
<behaviors>
<serviceBehaviors >
<behavior name="ServiceBehavior">
<serviceCredentials>
<serviceCertificate findValue="localhost" storeLocation="LocalMachine" storeName="My" x509FindType="FindBySubjectName" />
**<!-- Retain your custom username password validator here -->**
</serviceCredentials>
<serviceMetadata httpGetEnabled="True" httpsGetEnabled="True" />
<serviceDebug includeExceptionDetailInFaults="False" />
</behavior>
</serviceBehaviors>
</behaviors>
<bindings>
<netHttpBinding>
<binding name="netHttpBinding">
<security mode="TransportWithMessageCredential">
<message clientCredentialType="UserName"/>
</security>
</binding>
</netHttpBinding>
</bindings>
<protocolMapping>
<add scheme="https" binding="netHttpBinding"/>
</protocolMapping>
</system.serviceModel>
</configuration>