Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Perl) 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.
use chilkat(); # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. $cert = chilkat::CkCert->new(); $success = $cert->LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123"); if ($success == 0) { print $cert->lastErrorText() . "\r\n"; exit; } $fac = chilkat::CkFileAccess->new(); $fileBytes = chilkat::CkByteData->new(); $success = $fac->ReadEntireFile("qa_data/pdf/sample.pdf",$fileBytes); if ($fac->get_LastMethodSuccess() != 1) { print $fac->lastErrorText() . "\r\n"; exit; } $crypt = chilkat::CkCrypt2->new(); $success = $crypt->SetSigningCert($cert); # We can sign any type of file. $sigBytes = chilkat::CkByteData->new(); $success = $crypt->OpaqueSignBytes($fileBytes,$sigBytes); if ($crypt->get_LastMethodSuccess() != 1) { print $crypt->lastErrorText() . "\r\n"; exit; } $success = $fac->WriteEntireFile("qa_output/sample.pdf.p7m",$sigBytes); if ($fac->get_LastMethodSuccess() != 1) { print $fac->lastErrorText() . "\r\n"; exit; } # We can verify the opaque signature and extract the original data like this $originalData = chilkat::CkByteData->new(); $success = $crypt->OpaqueVerifyBytes($sigBytes,$originalData); if ($crypt->get_LastMethodSuccess() != 1) { print $crypt->lastErrorText() . "\r\n"; exit; } $success = $fac->WriteEntireFile("qa_output/sample.pdf",$originalData); if ($fac->get_LastMethodSuccess() != 1) { print $fac->lastErrorText() . "\r\n"; exit; } print "Signature is verified and the original data was extracted." . "\r\n"; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.