Sample code for 30+ languages & platforms
PowerShell

Send Signed Email using PFX File (long version)

Demonstrates how to send a signed email using a digital certificate w/ private key stored in a PFX file.

Chilkat PowerShell Downloads

PowerShell
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"

$success = $false

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

# The mailman object is used for sending and receiving email.
$mailman = New-Object Chilkat.MailMan

# Set the SMTP server.
$mailman.SmtpHost = "smtp.mymailserver.com"

# Create a new email object
$email = New-Object Chilkat.Email

$email.Subject = "This email is signed"
$email.Body = "This is a digitally signed mail"
$email.From = "Chilkat Admin <admin@chilkatsoft.com>"
$success = $email.AddTo("Chilkat Support","support@chilkatsoft.com")

# Indicate that the email should be sent signed.
$email.SendSigned = $true

# Load a PFX file into a certificate store object.
# Then locate the certificate matching the  sender's email address,
# and use it for signing.
# (a PFX file may contain more than one certificate.)
$certStore = New-Object Chilkat.CertStore
# The 1st argument is the path of the PFX file, the 2nd arg is the 
# PFX file's password:
$success = $certStore.LoadPfxFile("/pfx_files/chilkatsoft_secret.pfx","secret")
if ($success -ne $true) {
    $($certStore.LastErrorText)
    exit
}

# Find the certificate for the email address:
$jsonE = New-Object Chilkat.JsonObject
$jsonE.UpdateString("email","admin@chilkatsoft.com")

$cert = New-Object Chilkat.Cert
$success = $certStore.FindCert($jsonE,$cert)
if ($success -eq $false) {
    $($certStore.LastErrorText)
    exit
}

# Alternatively, 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:
$cert2 = New-Object Chilkat.Cert
# The 1st argument is the filename, the 2nd arg is the 
# PFX file's password:
$success = $cert2.LoadPfxFile("/pfx_files/chilkatsoft_secret.pfx","secret")
if ($success -ne $true) {
    $($cert2.LastErrorText)
    exit
}

# This example will use the cert from the certStore...
$success = $email.SetSigningCert($cert)

# Signed email can be sent in two different ways.  
# In a multipart/signed email, the signature is attached as a separate MIME part.
# In an opaque email (signedData) the content of the email is encapsulated within the signature
# and the email is sent as "application/pkcs7-mime". 
# Either should be fine, but some receiving systems might require one or the other..
$mailman.OpaqueSigning = $false

# Send a signed email.
$success = $mailman.SendEmail($email)
if ($success -ne $true) {
    $($mailman.LastErrorText)
}
else {
    # The LastErrorText property provides information
    # even when successful.
    $($mailman.LastErrorText)
    $("Mail Sent!")
}