Sample code for 30+ languages & platforms
Classic ASP

Decrypt S/MIME and Verify S/MIME Signatures

See more MIME Examples

_LANGUAGE_ example to decrypt S/MIME and verify S/MIME signatures. The S/MIME is unwrapped to get the original MIME prior to signing/encrypting.

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 requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

set mime = Server.CreateObject("Chilkat.Mime")

' Load an S/MIME message from a file:
success = mime.LoadMimeFile("signedMime.txt")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( mime.LastErrorText) & "</pre>"
    Response.End
End If

' The ContainsEncryptedParts/ContainsSignedParts methods
' can be called to determine if the MIME is encrypted and/or signed:
isEncrypted = mime.ContainsEncryptedParts()
isSigned = mime.ContainsSignedParts()

' We don't want the "unwrap extras".  You'll see what those
' are in a few moments...
mime.UnwrapExtras = 0

' To verify the signature, call UnwrapSecurity.  This will
' verify the signature(s) and decrypt the S/MIME and restore
' the MIME to the unsigned/unencrypted state.
' The results of what was found are present in the MIME object's
' properties, as well as extra header fields that are added
' to the unwrapped MIME.
success = mime.UnwrapSecurity()
If (success <> 1) Then
    ' UnwrapSecurity returns 1 if all signatures were
    ' verified and all parts decrypted.
    Response.Write "<pre>" & Server.HTMLEncode( mime.LastErrorText) & "</pre>"
    Response.End
End If

' The mime.UnwrapExtras property controls whether or not
' these additional fields are added to the unwrapped MIME:
' 
' X-NumPartsSigned: 1
' X-SignaturesValid: yes
' X-NumPartsEncrypted: 1
' X-Decrypted: no
' 
' The X-NumPartsSigned/X-SignaturesValid headers are added
' if the MIME was signed.  
' 
' The X-NumPartsEncrypted/X-Decrypted headers are added
' if the MIME was encrypted.
' 

' If the MIME was signed, get the certificate used for signing.
If (isSigned = 1) Then
    set signerCert = Server.CreateObject("Chilkat.Cert")

    ' The NumSignerCerts property indicates how many certificates
    ' were used for signing.  This example will assume the value is 1.
    ' To get the 1st signer cert, call LastSignerCert with an index of 0:
    success = mime.LastSignerCert(0,signerCert)
    If (success = 1) Then
        Response.Write "<pre>" & Server.HTMLEncode( "**** Signer Cert: " & signerCert.SubjectCN) & "</pre>"
    End If

End If

' If the MIME was encrypted, get the certificate used for decryption
If (isEncrypted = 1) Then
    ' The NumDecryptCerts property indicates how many certificates
    ' were used for decrypting.  This example will assume the value is 1.
    ' To get the 1st decrypt cert, call LastDecryptCert with an index of 0:
    set decryptCert = Server.CreateObject("Chilkat.Cert")
    success = mime.LastDecryptCert(0,decryptCert)
    If (success = 1) Then
        Response.Write "<pre>" & Server.HTMLEncode( "**** Decrypt Cert: " & decryptCert.SubjectCN) & "</pre>"
    End If

End If

' Display the unwrapped MIME:
Response.Write "<pre>" & Server.HTMLEncode( mime.GetMime()) & "</pre>"

' Save the unwrapped MIME to a file:
success = mime.SaveMime("unwrappedMime.txt")

%>
</body>
</html>