У меня есть пользовательская реализация ClientCredentials в WCF. Два базовых свойства ClientCredentials - это ClientCertificate и ServiceCertificate, как показано здесь (MSDN) .
В моей конфигурации у меня установлен пользовательский ClientCredentials и определены оба сертификата:
<endpointBehaviors>
<behavior name="MyCustomEndpointBehavior">
<clientCredentials type="MyApp.Security.CentralAuthClientCredentials, MyApp">
<clientCertificate findValue="localhost" x509FindType="FindBySubjectName" storeLocation="CurrentUser" storeName="My" />
<serviceCertificate>
<defaultCertificate findValue="localhost" x509FindType="FindBySubjectName" storeLocation="CurrentUser" storeName="My" />
<authentication certificateValidationMode="None" revocationMode="NoCheck" />
</serviceCertificate>
</clientCredentials>
</behavior>
</endpointBehaviors>
Эта конфигурация была полностью 100% , работающей с аутентификацией UserName. Он использовал сертификаты для шифрования имени пользователя и пароля для сообщения. Затем я изменил свой пользовательский ClientCredentials.
Во время выполнения вот свойства, которые установлены на моем CentralAuthClientCredentials:
this.ClientCertificate = System.ServiceModel.Security.X509CertificateInitiatorClientCredential
this.ClientCertificate.Certificate = null
this.ServiceCertificate = System.ServiceModel.Security.X509CertificateRecipientClientCredential
this.ServiceCertificate.DefaultCertificate = null
Итак, почему клиент и сервисный сертификат по умолчанию, которые определены в конфигурации , а не , установлены на фактическом объекте-экземпляре? Похоже, что WCF полностью проигнорировал теги XML!
Есть ли какой-нибудь код, который я могу использовать, возможно, в конструкторе учетных данных, чтобы получить эти сертификаты из конфигурации вручную?
Спасибо за любую помощь!
Обновление
Я идиот. Я понял. WCF действительно правильно создавал мой экземпляр с набором сертификатов, но в моем клиенте wcf у меня была следующая серия удаления / добавления, которую я думаю скопировал из примера MSDN:
this.ChannelFactory.Endpoint.Behaviors.Remove<ClientCredentials>();
this.ChannelFactory.Endpoint.Behaviors.Add(new CentralAuthClientCredentials());
return base.Channel.MyServiceMethod();
Чтобы удалить старые учетные данные и добавить мои собственные. Однако это делало новый экземпляр, для которого не были установлены сертификаты! ой!