Sample code for 30+ languages & platforms
C

About RSA Public/Private Keys

See more RSA Examples

This 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.

Chilkat C Downloads

C
#include <C_CkCert.h>
#include <C_CkPublicKey.h>
#include <C_CkPrivateKey.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkCert cert;
    HCkPublicKey pubKey;
    HCkPrivateKey privKey;

    success = FALSE;

    cert = CkCert_Create();

    // Load a digital certificate.
    success = CkCert_LoadFromFile(cert,"digitalCert.cer");
    if (success == FALSE) {
        printf("%s\n",CkCert_lastErrorText(cert));
        CkCert_Dispose(cert);
        return;
    }

    // A .cer file does not contain the private key.  It should contain
    // the public key...
    pubKey = CkPublicKey_Create();
    CkCert_GetPublicKey(cert,pubKey);

    // Let's have a look at it (in XML format).
    printf("Public Key from Certificate:\n");
    printf("%s\n",CkPublicKey_getXml(pubKey));

    // 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 = CkPrivateKey_Create();

    success = CkPrivateKey_LoadAnyFormatFile(privKey,"PrivateKey.key","");
    if (success != TRUE) {
        printf("%s\n",CkPrivateKey_lastErrorText(privKey));
        CkCert_Dispose(cert);
        CkPublicKey_Dispose(pubKey);
        CkPrivateKey_Dispose(privKey);
        return;
    }

    // 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...).
    printf("Private Key from DER:\n");
    printf("%s\n",CkPrivateKey_getXml(privKey));


    CkCert_Dispose(cert);
    CkPublicKey_Dispose(pubKey);
    CkPrivateKey_Dispose(privKey);

    }