据我所知,TLS 1.1 要求 CertificateVerify 消息的内容是使用两个散列算法(MD5 和 SHA1)连接的数字签名值。使用 RSACryptoServiceProvider 在 .NET 中可以做到这一点吗?
这不起作用:
using (var rsa = new RSACryptoServiceProvider())
{
rsa.ImportParameters(...);
rsa.SignData(data, new MD5SHA1());
}
这也不起作用:
using (var rsa = new RSACryptoServiceProvider())
{
rsa.ImportParameters(...);
rsa.SignHash(new MD5SHA1().ComputeHash(data), "MD5SHA1");
}
(MD5SHA1 是 HashAlgorithm 的一种实现。)
推测这不起作用,因为签名嵌入了哈希算法的 OID,而 MD5-SHA1 没有有效的 OID。这在.NET中可能吗?我误解了 TLS 1.1 吗?