Sample code for 30+ languages & platforms
Chilkat2-Python

CAdES BES Detached Signature

See more Encryption Examples

Demonstrates how to create a CAdES BES detached signature file (.p7s).

Chilkat Chilkat2-Python Downloads

Chilkat2-Python
import sys
import chilkat2

success = False

# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

crypt = chilkat2.Crypt2()

# Use a digital certificate and private key from a PFX file (.pfx or .p12).
pfxPath = "/Users/chilkat/testData/pfx/acme.pfx"
pfxPassword = "test123"

cert = chilkat2.Cert()
success = cert.LoadPfxFile(pfxPath,pfxPassword)
if (success != True):
    print(cert.LastErrorText)
    sys.exit()

# Tell the crypt component to use this cert.
success = crypt.SetSigningCert(cert)
if (success != True):
    print(crypt.LastErrorText)
    sys.exit()

# The CadesEnabled property applies to all methods that create PKCS7 signatures. 
# To create a CAdES-BES signature, set this property equal to true. 
crypt.CadesEnabled = True

# We can sign any type of file, creating a .p7s as output:
inFile = "/Users/chilkat/testData/pdf/sample.pdf"
sigFile = "/Users/chilkat/testData/p7s/sample.p7s"

# Create the detached CAdES-BES signature:
success = crypt.CreateP7S(inFile,sigFile)
if (success == False):
    print(crypt.LastErrorText)
    sys.exit()

success = crypt.VerifyP7S(inFile,sigFile)
if (success == False):
    print(crypt.LastErrorText)
    sys.exit()

print("Success!")