Sample code for 30+ languages & platforms
Classic ASP

Using Client Certificate w/ IMAP SSL

Demonstrates how to use a client-side certificate with an IMAP SSL connection. The SetSslClientCert method is called to specify a certificate to be used for the SSL connection.

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

set imap = Server.CreateObject("Chilkat.Imap")

' To use a secure SSL connection, set SSL and the port:
imap.Ssl = 1
' The typical port for IMAP SSL is 993
imap.Port = 993

' Load a certificate from a PFX file and use it.
' Note: Other methods are available to load pre-installed
' certificates from registry-based certificate stores.

' Create an instance of a certificate store object, load a PFX file,
' locate the certificate we need, and use it for signing.
' (a PFX file may contain more than one certificate.)
set certStore = Server.CreateObject("Chilkat.CertStore")
' The 1st argument is the filename, the 2nd arg is the 
' PFX file's password:
success = certStore.LoadPfxFile("myCertWithPrivateKey.pfx","secret")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( certStore.LastErrorText) & "</pre>"
    Response.End
End If

' Find the certificate by the subject common name:
set jsonCN = Server.CreateObject("Chilkat.JsonObject")
success = jsonCN.UpdateString("CN","cert common name")

set cert = Server.CreateObject("Chilkat.Cert")
success = certStore.FindCert(jsonCN,cert)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( certStore.LastErrorText) & "</pre>"
    Response.End
End If

' If a PFX file is known to contain a single certificate,
' you may load it directly into a Chilkat certificate object.
' This snippet of source code shows how:
set cert2 = Server.CreateObject("Chilkat.Cert")
' The 1st argument is the filename, the 2nd arg is the 
' PFX file's password:
success = cert2.LoadPfxFile("myClientCert.pfx","secret")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( cert.LastErrorText) & "</pre>"
    Response.End
End If

' Use the cert:
success = imap.SetSslClientCert(cert)

' Connect to an IMAP server.
success = imap.Connect("imap.example.com")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( imap.LastErrorText) & "</pre>"
    Response.End
End If

' Login
success = imap.Login("myLogin","myPassword")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( imap.LastErrorText) & "</pre>"
    Response.End
End If

' Select an IMAP mailbox
success = imap.SelectMailbox("Inbox")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( imap.LastErrorText) & "</pre>"
    Response.End
End If

' Get the message IDs of all the emails in the mailbox
fetchUids = 1
set messageSet = Server.CreateObject("Chilkat.MessageSet")
success = imap.QueryMbx("ALL",fetchUids,messageSet)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( imap.LastErrorText) & "</pre>"
    Response.End
End If

' Fetch the emails into a bundle object:
set bundle = Server.CreateObject("Chilkat.EmailBundle")
headersOnly = 0
success = imap.FetchMsgSet(headersOnly,messageSet,bundle)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( imap.LastErrorText) & "</pre>"
    Response.End
End If

' Loop over the bundle and display the FROM and SUBJECT of each.
set email = Server.CreateObject("Chilkat.Email")
i = 0
numEmails = bundle.MessageCount
Do While i < numEmails
    success = bundle.EmailAt(i,email)

    Response.Write "<pre>" & Server.HTMLEncode( email.From) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( email.Subject) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "--") & "</pre>"
    i = i + 1
Loop

' Disconnect from the IMAP server.
success = imap.Disconnect()

%>
</body>
</html>