我们运行一个 WCF 服务,该服务使用(相互)证书进行加密和签名。到目前为止,一切正常。
问题是:几周后我们需要更换服务证书。我们希望在服务器和客户端上相互独立地实现更改,因此不需要密切协调活动。以下是我们理想中想要采取的步骤:
- 在证书存储中安装新的服务证书(那里没问题)
- 配置 WCF 服务,使其可以同时使用旧证书和新证书。此时,服务器应该能够接受使用旧公钥和新公钥加密的请求,具体取决于客户端使用的密钥。客户端仍将使用旧证书。
- 将客户端配置为使用新证书。
- 从证书存储中删除旧证书。
我的问题出在第 2 步。我找不到任何关于如何配置服务的参考资料,因此它能够使用这两种证书并根据请求中的参数(例如 SubjectKeyIdentifier)选择正确的证书。看来我特地要告诉 WCF 使用哪个服务证书。下面是我们服务器配置中的相关片段(我们使用自定义绑定,但我想这在这里无关紧要)。在这种情况下,我们根据主题名称识别证书。
<serviceBehaviors>
<behavior name="SecurityBehavior">
...
<serviceCredentials>
<clientCertificate>
<authentication certificateValidationMode="PeerTrust"/>
</clientCertificate>
<serviceCertificate findValue="MyCertName" x509FindType="FindBySubjectName"/>
</serviceCredentials>
</behavior>
</serviceBehaviors>
</behaviors>
问题:是否可以摆脱特定的定义(并且仍然有服务工作),以便服务动态选择正确的证书?那将如何运作?
非常感谢您的意见!