我收到了来自第 3 方网络服务的响应。我用该响应加载了一个 XmlDocument。
string txt = readStream.ReadToEnd();
response = new XmlDocument();
response.PreserveWhitespace = true;
response.LoadXml(txt);
return response;
现在我想验证响应是否使用证书签名。我有一个VerifyXmlDoc(XmlDocument xmlDoc)
我在msdn上找到的方法。
我知道消息是正确的。
public bool VerifyXmlDoc(XmlDocument xmlDoc)
{
SignedXml signed = new SignedXml(xmlDoc);
XmlNodeList signatureNodeList = xmlDoc.GetElementsByTagName("Signature");
signed.LoadXml((XmlElement)signatureNodeList[0]);
X509Certificate2 serviceCertificate = null;
foreach (KeyInfoClause clause in signed.KeyInfo)
{
if (clause is KeyInfoX509Data)
{
if (((KeyInfoX509Data)clause).Certificates.Count > 0)
{
serviceCertificate = (X509Certificate2)((KeyInfoX509Data)clause).Certificates[0];
}
}
}
bool result = signed.CheckSignature(serviceCertificate, true);
return result;
}
如果我将项目的目标框架设置为 .NET 3.5 或 .NET 3 或 .NET 2,效果会很好。结果是真的。但是如果我将目标框架更改为 .NET 4 结果是错误的。(而且我必须使用 .NET 4)
关于如何解决这个问题的任何想法?