![]() |
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
(PHP Extension) About RSA Public/Private KeysThis example provides some additional information for understanding public/private key pairs. In demonstrates how a private key is a superset of the public key. A public key contains the modulus and exponent. The matching private key also contains the modulus and exponent, but also contains the additional private key parts.
<?php include("chilkat.php"); // Use "chilkat_9_5_0.php" for versions of Chilkat < 10.0.0 $cert = new CkCert(); // Load a digital certificate. $success = $cert->LoadFromFile('digitalCert.cer'); if ($success != true) { print $cert->lastErrorText() . "\n"; exit; } // A .cer file does not contain the private key. It should contain // the public key... // pubKey is a CkPublicKey $pubKey = $cert->ExportPublicKey(); // Let's have a look at it (in XML format). print 'Public Key from Certificate:' . "\n"; print $pubKey->getXml() . "\n"; // An RSA public key consists of a modulus and exponent. // An RSA private key includes both the modulus and exponent, // as well as other "big" numbers: P, Q, D, etc. // Let's load an RSA private key from a DER-encoded file: $privKey = new CkPrivateKey(); $success = $privKey->LoadAnyFormatFile('PrivateKey.key',''); if ($success != true) { print $privKey->lastErrorText() . "\n"; exit; } // If this private key is the matching half to the public key from // the certificate, then the modulus and exponent should // be identical. (Thus, a "private key" really contains both the public part as well as the private parts...). print 'Private Key from DER:' . "\n"; print $privKey->getXml() . "\n"; ?> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.