PHP ActiveX
PHP ActiveX
Sign a Byte Array to Create an Opaque Signature in a Byte Array
See more Digital Signatures Examples
Signs 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.Chilkat PHP ActiveX Downloads
<?php
$success = 0;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
$cert = new COM("Chilkat.Cert");
$success = $cert->LoadPfxFile('qa_data/pfx/cert_test123.pfx','test123');
if ($success == 0) {
print $cert->LastErrorText . "\n";
exit;
}
$fac = new COM("Chilkat.FileAccess");
$fileBytes = $fac->ReadEntireFile('qa_data/pdf/sample.pdf');
if ($fac->LastMethodSuccess != 1) {
print $fac->LastErrorText . "\n";
exit;
}
$crypt = new COM("Chilkat.Crypt2");
$success = $crypt->SetSigningCert($cert);
// We can sign any type of file.
$sigBytes = $crypt->OpaqueSignBytes($fileBytes);
if ($crypt->LastMethodSuccess != 1) {
print $crypt->LastErrorText . "\n";
exit;
}
$success = $fac->WriteEntireFile('qa_output/sample.pdf.p7m',$sigBytes);
if ($fac->LastMethodSuccess != 1) {
print $fac->LastErrorText . "\n";
exit;
}
// We can verify the opaque signature and extract the original data like this
$originalData = $crypt->OpaqueVerifyBytes($sigBytes);
if ($crypt->LastMethodSuccess != 1) {
print $crypt->LastErrorText . "\n";
exit;
}
$success = $fac->WriteEntireFile('qa_output/sample.pdf',$originalData);
if ($fac->LastMethodSuccess != 1) {
print $fac->LastErrorText . "\n";
exit;
}
print 'Signature is verified and the original data was extracted.' . "\n";
?>