Visual C++ Examples

ChilkatHOMEASPVisual BasicVB.NETC#Visual C++CMFCDelphiFoxProJavaPerlPHPPythonRubySQL ServerVBScript

Visual C++ Examples

CkString
Byte Array
Bounced Mail
Bz2
Character Encoding
CSV
DH Key Exchange
DKIM/DomainKeys
Digital Certificates
Digital Signatures
DSA
Email
Encryption
FTP
HTML-to-XML
HTTP
IMAP
MHT / HTML Email
POP3
RSA
S/MIME
SMTP
Socket
Spider
SSH Key
SSH
SSH Tunnel
SFTP
Tar
Upload
XML
XMP
Zip Compression


More Examples...
Email Object
NTLM
FileAccess
RSS
Atom
Self-Extractor
Service
PPMD
Deflate
Bzip2
LZW

 

 

 

 

 

 

 

 

SSL Server Example

Demonstrates how to create an SSL socket for accepting connections. This example is *very* simple in that it will create an SSL socket for accepting a single connection. It will read a message from the client, send a reply, and exit.

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

Download Chilkat C/C++ Libraries for VC++ 10.0 / x64

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

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

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

#include <CkSocket.h>
#include <CkCertStore.h>
#include <CkCert.h>

void ChilkatSample(void)
    {
    CkSocket listenSslSocket;

    //  Any string automatically begins a fully-functional 30-day trial.
    bool success;
    success = listenSslSocket.UnlockComponent("Anything for 30-day trial");
    if (success != true) {
        printf("Failed to unlock component\n");
        return;
    }

    //  An SSL server needs a digital certificate.  This example loads it from a PFX file.

    //  Create an instance of a certificate store object, load a PFX file,
    //  locate the certificate we need, and use it.
    //  (a PFX file may contain more than one certificate.)
    CkCertStore certStore;
    //  The 1st argument is the filename, the 2nd arg is the
    //  PFX file's password:
    success = certStore.LoadPfxFile("chilkat.pfx","test");
    if (success != true) {
        printf("%s\n",certStore.lastErrorText());
        return;
    }

    //  Find the certificate to be used for SSL:
    CkCert *cert = 0;
    cert = certStore.FindCertBySubject("Chilkat Software, Inc.");
    if (cert == 0 ) {
        printf("%s\n",certStore.lastErrorText());
        return;
    }

    //  Use the certificate:
    success = listenSslSocket.InitSslServer(*cert);
    if (success != true) {
        printf("%s\n",listenSslSocket.lastErrorText());
        return;
    }

    //  Bind and listen on a port:
    long myPort;
    myPort = 8123;
    //  Allow for a max of 5 queued connect requests.
    long backLog;
    backLog = 5;
    success = listenSslSocket.BindAndListen(myPort,backLog);
    if (success != true) {
        printf("%s\n",listenSslSocket.lastErrorText());
        return;
    }

    //  If accepting an SSL/TLS connection, the SSL handshake is part of the connection
    //  establishment process. This involves a few back-and-forth messages between the
    //  client and server to establish algorithms and a shared key to create the secure
    //  channel. The sending and receiving of these messages are governed by the
    //  MaxReadIdleMs and MaxSendIdleMs properties. If these properties are set to 0
    //  (and this is the default unless changed by your application), then the
    //  AcceptNextConnection can hang indefinitely during the SSL handshake process.
    //  Make sure these properties are set to appropriate values before calling AcceptNextConnection.

    //  Set a 10 second max for waiting to read/write.  This is for the SSL/TLS handshake establishment.
    listenSslSocket.put_MaxReadIdleMs(10000);
    listenSslSocket.put_MaxSendIdleMs(10000);

    //  Accept a single client connection and establish the secure SSL/TLS channel:
    CkSocket *clientSock = 0;
    long maxWaitMillisec;
    maxWaitMillisec = 20000;
    clientSock = listenSslSocket.AcceptNextConnection(maxWaitMillisec);
    if (clientSock == 0 ) {
        printf("%s\n",listenSslSocket.lastErrorText());
        return;
    }

    //  The client (in this example) is going to send a "Hello Server! -EOM-"
    //  message.  Read it:
    const char * receivedMsg;
    receivedMsg = clientSock->receiveUntilMatch("-EOM-");
    if (receivedMsg == 0 ) {
        printf("%s\n",clientSock->lastErrorText());
        return;
    }

    printf("%s\n",receivedMsg);

    //  Send a "Hello Client! -EOM-" message:
    success = clientSock->SendString("Hello Client! -EOM-");
    if (success != true) {
        printf("%s\n",clientSock->lastErrorText());
        return;
    }

    //  Close the connection with the client
    //  Wait a max of 20 seconds (20000 millsec)
    clientSock->Close(20000);
    }

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

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

Mail Component · .NET Mail Component · XML Parser