我使用ASP.NET,C#和iTextSharp 5.3.0来创建和数字签名PDF。然后我需要在签名时使用pfx文件。有人能解释一下它会包含什么吗?
修改
谢谢,所以它有密钥对。
我确实使用过此代码。
FileStream fs = new FileStream(CERT_PATH, FileMode.Open);
Pkcs12Store ks = new Pkcs12Store(fs, CERT_PASSW.ToCharArray());
string alias = null;
foreach (string al in ks.Aliases)
{
if (ks.IsKeyEntry(al) && ks.GetKey(al).Key.IsPrivate)
{
alias = al;
break;
}
}
Certificate[] x = ks.getCertificateChain(alias)
X509Certificate[] chain=new X509Certificate[x.length]
for(int k=0;k<x.length;k++)
{
chain[k]=x[k].Certificate;
}
谢谢,现在工作正常。
答案 0 :(得分:2)
请阅读有关iText和数字签名的白皮书:http://itextpdf.com/book/digitalsignatures
PFX文件是包含私钥和公钥对的旧类型文件。您可以像使用P12文件一样使用它。这在文档中有解释。请注意,Stackoverflow上的旧答案不再适用。数字签名功能已完全重写。
如果您不知道如何在C#中创建KeyStore:
FileStream fs = new FileStream(CERT_PATH, FileMode.Open);
Pkcs12Store ks = new Pkcs12Store(fs, CERT_PASSW.ToCharArray());
string alias = null;
foreach (string al in ks.Aliases) {
if (ks.IsKeyEntry(al) && ks.GetKey(al).Key.IsPrivate) {
alias = al;
break;
}
}