Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PowerBuilder) Sign a Byte Array to Create an Opaque Signature in a Byte ArraySigns data contained in a byte array to produce an opaque signature (also in a byte array). An opaque signature is a PKCS7 signature (also known as CAdES) that embeds the signed data. Also shows how to verify the signature and extract the original data.
integer li_rc oleobject loo_Cert integer li_Success oleobject loo_Fac oleobject loo_Crypt // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. loo_Cert = create oleobject // Use "Chilkat_9_5_0.Cert" for versions of Chilkat < 10.0.0 li_rc = loo_Cert.ConnectToNewObject("Chilkat.Cert") if li_rc < 0 then destroy loo_Cert MessageBox("Error","Connecting to COM object failed") return end if li_Success = loo_Cert.LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123") if li_Success = 0 then Write-Debug loo_Cert.LastErrorText destroy loo_Cert return end if loo_Fac = create oleobject // Use "Chilkat_9_5_0.FileAccess" for versions of Chilkat < 10.0.0 li_rc = loo_Fac.ConnectToNewObject("Chilkat.FileAccess") loo_FileBytes = loo_Fac.ReadEntireFile("qa_data/pdf/sample.pdf") if loo_Fac.LastMethodSuccess <> 1 then Write-Debug loo_Fac.LastErrorText destroy loo_Cert destroy loo_Fac return end if loo_Crypt = create oleobject // Use "Chilkat_9_5_0.Crypt2" for versions of Chilkat < 10.0.0 li_rc = loo_Crypt.ConnectToNewObject("Chilkat.Crypt2") li_Success = loo_Crypt.SetSigningCert(loo_Cert) // We can sign any type of file. loo_SigBytes = loo_Crypt.OpaqueSignBytes(loo_FileBytes) if loo_Crypt.LastMethodSuccess <> 1 then Write-Debug loo_Crypt.LastErrorText destroy loo_Cert destroy loo_Fac destroy loo_Crypt return end if li_Success = loo_Fac.WriteEntireFile("qa_output/sample.pdf.p7m",loo_SigBytes) if loo_Fac.LastMethodSuccess <> 1 then Write-Debug loo_Fac.LastErrorText destroy loo_Cert destroy loo_Fac destroy loo_Crypt return end if // We can verify the opaque signature and extract the original data like this loo_OriginalData = loo_Crypt.OpaqueVerifyBytes(loo_SigBytes) if loo_Crypt.LastMethodSuccess <> 1 then Write-Debug loo_Crypt.LastErrorText destroy loo_Cert destroy loo_Fac destroy loo_Crypt return end if li_Success = loo_Fac.WriteEntireFile("qa_output/sample.pdf",loo_OriginalData) if loo_Fac.LastMethodSuccess <> 1 then Write-Debug loo_Fac.LastErrorText destroy loo_Cert destroy loo_Fac destroy loo_Crypt return end if Write-Debug "Signature is verified and the original data was extracted." destroy loo_Cert destroy loo_Fac destroy loo_Crypt |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.