MFC Examples

ChilkatHOMEASPVisual BasicVB.NETC#Visual C++CMFCDelphiFoxProJavaPerlPHPPythonRubySQL ServerVBScript

MFC Examples

Bounced Mail
Bz2
Certificates/Keys
Charset
CSV
Diffie-Hellman
DSA
Email Object
Encryption
FileAccess
FTP
HTML-to-XML
HTTP
IMAP
MHT / HTML Email
MIME
POP3
RSA
SMTP
Socket
Spider
SSH Key
SSH
SSH Tunnel
SFTP
Tar
Upload
XML
Zip


 

 

 

 

 

 

 

 

DSA Generate Key

Generates a DSA public/private key pair and saves to PEM and DER file formats (both encrypted and non-encrypted).

An encrypted DSA PEM looks like this:

-----BEGIN DSA PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
DEK-Info: DES-EDE3-CBC,9DAFD5C4CD62A5D0

QwDdp66sB0qKXQli7FbVcKL/eo3wu7kGRlV2sI8XbkNa1RTLiwnwTWDB0dqyWRQ8
...
Bx0HVfxKiNgCbL6BQEnYD+GOmMcckuj9Uhgloe/YuXCIDJBGhjUt/li3hvR/PXeC

V2xxNl1XKBE88njqi+UXt4vjGVNLpvXM
-----END DSA PRIVATE KEY-----

Download Chilkat C/C++ Libraries for VC++ 9.0 / Win32

Download Chilkat C/C++ Libraries for VC++ 8.0 / Win32

Download Chilkat C/C++ 64-bit Libraries for VC++ 8.0 / x64

Download Chilkat Visual Studio 2005 C/C++ Libs for Windows Mobile, Pocket PC, SmartPhone, WinCE

Download Chilkat C/C++ Libraries for VC++ 7.0 / Win32

Download Chilkat C/C++ Libraries for VC++ 6.0 / Win32

Download Chilkat C/C++ Libraries for VC++ 6.0, Win 95/98/NT4 Compatible

// Needs #include <CkDsa.h>

    CkString strOut;

    bool success;

    CkDsa dsa;

    success = dsa.UnlockComponent("Anything for 30-day trial");
    if (success != true) {
        strOut.append(dsa.lastErrorText());
        strOut.append("\r\n");
        SetDlgItemText(IDC_EDIT1,strOut.getUnicode());
        return;
    }

    //  Call GenKey to generate a new DSA key.
    //  The number of bits should be at least 1024 and a multiple
    //  of 64.   Typical values are either 1024 or 2048.
    //  DSA key generation is compute intensive and may take
    //  a short while to complete.
    success = dsa.GenKey(2048);
    if (success != true) {
        strOut.append(dsa.lastErrorText());
        strOut.append("\r\n");
        SetDlgItemText(IDC_EDIT1,strOut.getUnicode());
        return;
    }

    //  Extract the private and public parts to PEM or DER format
    //  and save to files...
    const char * pemStr;
    const char * xmlStr;

    //  First for the public key...
    //  The public key never needs to be encrypted.

    //  Save the public key in PEM format:
    pemStr = dsa.toPublicPem();
    //  This example will not check the return value of SaveText...
    success = dsa.SaveText(pemStr,"dsa_pub.pem");

    //  Save the public key in DER format:
    success = dsa.ToPublicDerFile("dsa_pub.der");

    bool bPublicOnly;
    bPublicOnly = true;
    //  Save to XML
    xmlStr = dsa.toXml(bPublicOnly);
    success = dsa.SaveText(pemStr,"dsa_pub.xml");

    //  ------------------------------------
    //  Now for the private key....
    //  ------------------------------------

    //  Unencrypted PEM:
    pemStr = dsa.toPem();
    success = dsa.SaveText(pemStr,"dsa_priv.pem");

    //  Encrypted PEM:
    pemStr = dsa.toEncryptedPem("myPassword");
    success = dsa.SaveText(pemStr,"dsa_privEncrypted.pem");

    //  DER:
    success = dsa.ToDerFile("dsa_priv.der");

    //  XML:
    bPublicOnly = false;
    xmlStr = dsa.toXml(bPublicOnly);
    success = dsa.SaveText(pemStr,"dsa_priv.xml");

    strOut.append("Finished!\r\n");

    SetDlgItemText(IDC_EDIT1,strOut.getUnicode());

Need a specific example? Send a request to support@chilkatsoft.com

© 2000-2008 Chilkat Software, Inc. All Rights Reserved.