本页内容
读取数字签名信息
将分别读取文档持有的数字签名,签名持有的签名者,签名者持有的数字证书中的部分信息。
所有可获取的信息详见 API Reference。
读取数字签名信息的示例代码如下:
java
CPDFDocument document = new CPDFDocument(context);
document.open(FileUtils.getAssetsTempFile(context, "Signed.pdf"));
for (int i = 0; i < document.getSignatureCount(); i++) {
CPDFSignature signature = document.getPdfSignature(i);
// Check if the signer array exists and is not empty
if (signature.getSignerArr() != null && signature.getSignerArr().length > 0) {
CPDFSigner signer = signature.getSignerArr()[0];
CPDFOwnerInfo subject = signer.getCert().getCertInfo().getSubject();
System.out.println("Name: " + signature.getName());
System.out.println("Location: " + signature.getLocation());
System.out.println("Reason: " + signature.getReason());
System.out.println("Date: " + DateUtil.transformPDFDate(signature.getDate()));
System.out.println("Subject: " + subject.toString());
}
}
kotlin
val document = CPDFDocument(context)
document.open(getAssetsTempFile(context, "Signed.pdf"))
for (i in 0 until document.signatureCount) {
val signature = document.getPdfSignature(i)
// Check if the signer array exists and is not empty
if (signature.signerArr != null && signature.signerArr.isNotEmpty()) {
val signer = signature.signerArr[0]
val subject = signer.cert.certInfo.subject
println("Name: ${signature.name}")
println("Location: ${signature.location}")
println("Reason: ${signature.reason}")
println("Date: ${transformPDFDate(signature.date)}")
println("Subject: $subject")
}
}
数字签名、签名者、证书的关系
数字签名是通过使用签名者的私钥对文档进行加密生成的,然后使用签名者的证书中的公钥来验证签名的有效性。签名、签名者、数字证书一起构成了PDF文档中数字签名的关键部分。
一般情况下,一个签名对应一个签名者。但在某些情况下,一个数字签名可以包含多个签名者,每个签名者可以拥有自己的证书链。这种多签名者的机制在某些应用场景下非常有用,因为它允许多个实体对同一文档进行数字签名,每个实体可以使用自己的证书和私钥。