C
C
Certify a PDF and Lock the Entire Document
See more PDF Signatures Examples
This example demonstrates how to a sign a certify a PDF and lock the entire document. Normally this is intended to seal the document with a final approving (or dissapproving) signature; usually after a review workflow is completed and normally reserved for the creator or author of a document.Chilkat C Downloads
#include <C_CkPdf.h>
#include <C_CkJsonObject.h>
#include <C_CkCert.h>
void ChilkatSample(void)
{
BOOL success;
HCkPdf pdf;
HCkJsonObject json;
HCkCert cert;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
pdf = CkPdf_Create();
// Load a PDF to be certified and locked.
// The "hello.pdf" is available at https://chilkatsoft.com/hello.pdf
success = CkPdf_LoadFile(pdf,"qa_data/pdf/hello.pdf");
if (success == FALSE) {
printf("%s\n",CkPdf_lastErrorText(pdf));
CkPdf_Dispose(pdf);
return;
}
// Options for signing are specified in JSON.
json = CkJsonObject_Create();
// In most cases, the signingCertificateV2 and signingTime attributes are required.
CkJsonObject_UpdateInt(json,"signingCertificateV2",1);
CkJsonObject_UpdateInt(json,"signingTime",1);
// The only coding difference with certifying and locking a PDF
// as compared with an approval signature (also known as recipient signature)
// is to add the "lockAfterSigning" and "docMDP.add" to the json.
CkJsonObject_UpdateBool(json,"lockAfterSigning",TRUE);
CkJsonObject_UpdateBool(json,"docMDP.add",TRUE);
// Put the signature on page 1, top left
CkJsonObject_UpdateInt(json,"page",1);
CkJsonObject_UpdateString(json,"appearance.y","top");
CkJsonObject_UpdateString(json,"appearance.x","left");
// Use a font scale of 10.0
CkJsonObject_UpdateString(json,"appearance.fontScale","10.0");
// In this example, the appearance of the digital signature will contain three lines:
// 1) The signing certificate's common name
// 2) The current date/time
// 3) Some arbitrary text.
// The keyword "cert_cn" is replaced with the Certificate's Subject Common Name.
// The keyword "current_dt" is replaced with the current date/time.
// Any number of appearance text lines can be added.
CkJsonObject_UpdateString(json,"appearance.text[0]","Digitally signed by: cert_cn");
CkJsonObject_UpdateString(json,"appearance.text[1]","current_dt");
CkJsonObject_UpdateString(json,"appearance.text[2]","The crazy brown fox jumps over the lazy dog.");
// Load the signing certificate. (Use your own certificate.)
cert = CkCert_Create();
success = CkCert_LoadPfxFile(cert,"qa_data/pfx/myPdfSigningCert.pfx","secret");
if (success == FALSE) {
printf("%s\n",CkCert_lastErrorText(cert));
CkPdf_Dispose(pdf);
CkJsonObject_Dispose(json);
CkCert_Dispose(cert);
return;
}
// Tell the pdf object to use the certificate for signing.
success = CkPdf_SetSigningCert(pdf,cert);
if (success == FALSE) {
printf("%s\n",CkPdf_lastErrorText(pdf));
CkPdf_Dispose(pdf);
CkJsonObject_Dispose(json);
CkCert_Dispose(cert);
return;
}
success = CkPdf_SignPdf(pdf,json,"qa_output/hello_signed.pdf");
if (success == FALSE) {
printf("%s\n",CkPdf_lastErrorText(pdf));
CkPdf_Dispose(pdf);
CkJsonObject_Dispose(json);
CkCert_Dispose(cert);
return;
}
printf("The PDF has been successfully certified and locked.\n");
CkPdf_Dispose(pdf);
CkJsonObject_Dispose(json);
CkCert_Dispose(cert);
}