Perl Examples

ChilkatHOMEASPVisual BasicVB.NETC#Visual C++CMFCDelphiFoxProJavaPerlPHPPythonRubySQL ServerVBScript

Perl Examples

Quick Start
Perl Unicode
Perl Byte Array
Perl Certs
Perl Email
Perl Encryption
Perl FTP
HTML-to-XML
Perl HTTP
Perl IMAP
Perl MHT
Perl MIME
Perl RSA
Perl S/MIME
Perl Signatures
Perl Socket
Perl Spider
Perl Tar
Perl Upload
Perl XML
Perl XMP
Perl Zip

More Examples...
String
Email Object
POP3
SMTP
RSS
Atom
Self-Extractor

Unreleased...
Service
PPMD
Deflate
Bzip2
LZW
Bz2
DH Key Exchange
DSA
Icon

 

 

 

 

 

 

 

Create Complex Email

This is an example showing how to create an email that has file attachments, contains both plain-text and HTML alternative bodies, and has embedded images within the HTML. The email is saved to a .eml file, which is a text file and can be viewed in any text editor. EML is nothing more than the MIME source of an email. In this example, you'll see that the MIME is structured in three layers of multipart content types. The outermost layer is multipart/mixed. This is typically where you'll find file attachments and attached messages. Underneath the multipart/mixed is a multipart/related envelope. Within this you'll find the "related" items -- which are the items belonging to the HTML body (images and style sheets). Underneath the multipart/related you'll find the multipart/alternative, and this contains the text/plain and text/html alternative bodies.

Download Chilkat Perl Module

use chilkat;

#  Create a MailMan for the purpose
#  of unlocking the component.
$mailman = new chilkat::CkMailMan();
$mailman->UnlockComponent("anything for 30-day trial");

$email = new chilkat::CkEmail();

#  Adding attachments, HTML/plain-text bodies, etc can be done
#  in any order:

#  Add an attachment

$contentType = $email->addFileAttachment("hamlet.zip");
if ($contentType eq null ) {
    print $email->lastErrorText() . "\n";
    exit;
}

#  Add some headers:
$email->put_Subject("This is a complex email");
$email->AddTo("Chilkat Support",'support@chilkatsoft.com');
$email->put_From('Matt <matt@chilkatsoft.com>');

#  Add a plain-text body:
$email->AddPlainTextAlternativeBody("This is the plain-text body");

#  Add an image that will be embedded in the HTML body.
#  The contentType as derived from the file extension is returned.

$contentId = $email->addRelatedFile("dude.gif");

#  Add an HTML body:

$html = "<html><body><b>This is the HTML body</b><br><img src=\"cid:" . $contentId . "\"></body></html>";

$email->AddHtmlAlternativeBody($html);

#  Save the email as a .eml

$success = $email->SaveEml("complex.eml");
if ($success != 1) {
    print $email->lastErrorText() . "\n";
}
else {
    print "Created email!" . "\n";
}

 

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

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