PHP Extension
PHP Extension
ECDSA Sign Data and Get Raw R and S Values
See more ECC Examples
Demonstrates getting the raw R and S value of an ECDSA signature.Chilkat PHP Extension Downloads
<?php
include("chilkat.php");
$success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// To create an ECDSA signature, the data first needs to be hashed. Then the hash
// is signed.
$crypt = new CkCrypt2();
$crypt->put_HashAlgorithm('SHA256');
$crypt->put_Charset('utf-8');
$crypt->put_EncodingMode('base64');
// Hash a string.
$hash1 = $crypt->hashStringENC('The quick brown fox jumps over the lazy dog');
print 'hash1 = ' . $hash1 . "\n";
// -----------------------------------------------------------
// An ECDSA private key is used for signing. The public key is for signature verification.
// Load our ECC private key.
// Our private key file contains this:
// // -----BEGIN PRIVATE KEY-----
// MIGHAgEAMBMGByqGSM49AgEGCCqGSM49AwEHBG0wawIBAQQg3J8q/24D1sEKGdP9
// 72MGYElLGpw/a56Y3t6pfON3uhShRANCAATlSmoizyhAwoYZAOuFBATl07/1RR54
// a1Dzfm16grxJe666AGKR+bSs24hk7TEpaeCTvT8YOOM3l+xKFg7zq6Q9
// -----END PRIVATE KEY-----
$privKey = new CkPrivateKey();
$success = $privKey->LoadPemFile('qa_data/ecc/secp256r1-key-pkcs8.pem');
if ($success != true) {
print $privKey->lastErrorText() . "\n";
exit;
}
// Sign the hash..
$prng = new CkPrng();
$ecdsa = new CkEcc();
$ecdsaSigBase64 = $ecdsa->signHashENC($hash1,'base64',$privKey,$prng);
if ($ecdsa->get_LastMethodSuccess() != true) {
print $ecdsa->lastErrorText() . "\n";
exit;
}
// The ECDSA signature is ASN.1 that contains a sequence of 2 large integers (r and s)
// For example:
// SEQUENCE (2 elem)
// INTEGER (255 bit) 792134D9B4AD82D5431ED03835A88E2596EB35E5B13054BD9B05A0069281ACC9
// INTEGER (255 bit) 481E758CC1E3CBF825537EC3D9A2CA627E5FAD1137BBEA65DF38658DCB0A9ED5
print 'Base64 ECDSA signature = ' . $ecdsaSigBase64 . "\n";
// If the raw R and S values are needed, here's how to get them:
$asn = new CkAsn();
$success = $asn->LoadEncoded($ecdsaSigBase64,'base64');
if ($success == false) {
print $asn->lastErrorText() . "\n";
exit;
}
// The R and X will be in hexidecimal in the XML.
$xml = new CkXml();
$xml->LoadXml($asn->asnToXml());
print $xml->getXml() . "\n";
// The XML looks like this:
// <sequence>
// <int>792134D9B4AD82D5431ED03835A88E2596EB35E5B13054BD9B05A0069281ACC9</int>
// <int>481E758CC1E3CBF825537EC3D9A2CA627E5FAD1137BBEA65DF38658DCB0A9ED5</int>
// </sequence>
// Copy raw R and S hex values into a Chilkat BinData object.
$bd = new CkBinData();
$r = $xml->getChildContent('int[0]');
$s = $xml->getChildContent('int[1]');
$bd->AppendEncoded($r,'hex');
$bd->AppendEncoded($s,'hex');
print 'Number of bytes in bd: ' . $bd->get_NumBytes() . "\n";
?>