cfmail

Description

Sends an e-mail message that optionally contains query output, using an SMTP server.

Category

Internet Protocol tags

Syntax

<cfmail 
to = "recipient"
from = "sender"
cc = "copy_to"
bcc = "blind_copy_to"
subject = "msg_subject"
replyto = "reply_to_addr" failto = "fail_message_addr"
username = "user name"
password = "password"
wraptext = "column number"
charset = "character encoding"
type = "msg_type"
mimeattach = "path"
query = "query_name"
group = "query_column"
groupcasesensitive = "yes" or "no"
startrow = "query_row"
maxrows = "max_msgs"
server = "serverspecs"
port = "port_id"
mailerid = "headerid"
timeout = "seconds"
spoolenable = "yes" or "no"
debug = "yes" or "no"> (Optional) Mail message body and/or cfhttpparam tags </cfmail>

See also

cfmailparam, cfmailpart, cfpop, cfftp, cfhttp, cfldap, Wrap; Using ColdFusion with mail servers in Sending and Receiving E-Mail in ColdFusion MX Developer's Guide

ColdFusion MX 6.1:

ColdFusion MX: Added the SpoolEnable attribute.

Attributes

Attribute Req/Opt Default Description

to

Required

 

Message recipient e-mail addresses:

  • Static address; for example, "[email protected]".
  • Variable that contains an address; for example, "#Form.Email#".
  • Name of a query column that contains an address; for example, "#EMail#". An e-mail message is sent for each returned row.

from

Required

 

E-mail message sender:

  • A static string; for example, "[email protected]"
  • A variable; for example, "#GetUser.EMailAddress#" .

This attribute does not have to be a valid Internet address; it can be any text string.

cc

Optional

 

Address(es) to which to copy the message.

bcc

Optional

 

Address(es) to which to copy the message, without listing them in the message header.

subject

Required

 

Message subject. Can be dynamically generated. For example, to send messages that give customers status updates: "Status of Order Number #Order_ID#".

replyto

Optional

 

Address(es) to which the recipient is directed to send replies.

failto

Optional

 

Address to which mailing systems should send delivery failure notifications. Sets the mail envelope reverse-path value.

username

Optional

 

A user name to send to SMTP servers that require authentication. Requires a password attribute.

password

Optional

 

A password to send to SMTP servers that require authentication. Requires a username attribute.

wraptext

Optional

Do not wrap text

Specifies the maximum line length, in characters of the mail text. If a line has more than the specified number of characters, replaces the last white space character, such as a tab or space, preceding the specified position with a line break. If there are no white space characters, inserts a line break at the specified position. A common value for this attribute is 72.

charset

Optional

Character encoding selected in ColdFusion MX Administrator Mail page; default is UTF-8

Character encoding of the mail message, including the headers. The following list includes commonly used values:

  • utf-8
  • iso-8859-1
  • windows-1252
  • us-ascii
  • shift_jis
  • iso-2022-jp
  • euc-jp
  • euc-kr
  • iso-2022-kr
  • big5
  • hz-gb-2312
  • euc-cn
  • utf-16

For more information on character encodings, see
www.w3.org/International/O-charset.html.

type

Optional

text/plain

MIME type of the message. Can be a valid MIME media type or one of the following:

  • text: specifies text/plain type.
  • plain: specifies text/plain type.
  • html: specifies text/html type.

For a list of all registered MIME media types, see www.iana.org/assignments/media-types/.

MIMEAttach

Optional

 

Path of file to attach to message. Attached file is MIME-encoded. ColdFusion attempts to determine the MIME type of the file; use the cfmailparam tag to send an attachment and specify the MIME type.

query

Optional

 

Name of cfquery from which to draw data for message(s). Use this attribute to send more than one message, or to send query results within a message.

group

Optional

CurrentRow

Query column to use when you group sets of records to send as a message. For example, to send a set of billing statements to a customer, group on "Customer_ID." Case-sensitive. Eliminates adjacent duplicates when data is sorted by the specified field.

groupCase
Sensitive

Optional

No

Boolean. Whether to consider case when using the group attribute. To group on case-sensitive records, set this attribute to Yes.

startRow

Optional

1

Row in a query to start from.

maxRows

Optional

 

Maximum number of messages to send when looping over a query.

server

Optional

 

SMTP server address, or (Enterprise edition only) a comma-delimited list of server addresses, to use for sending messages. At least one server must be specified here or in the ColdFusion MX Administrator. A value here overrides the Administrator. A value that includes a port specification overrides the port attribute. See the Usage section for details.

port

Optional

 

TCP/IP port on which SMTP server listens for requests (normally 25). A value here overrides the Administrator.

mailerID

Optional

ColdFusion MX Application Server

Mailer ID to be passed in X-Mailer SMTP header, which identifies the mailer application.

timeout

Optional

 

Number of seconds to wait before timing out connection to SMTP server. A value here overrides the Administrator.

spoolEnable

Optional

 

Specifies whether to spool mail or always send it Immediately. Overrides the ColdFusion MX Administrator Spool mail messages to disk for delivery setting.

  • Yes: saves a copy of the message until the sending operation is complete. Pages that use this option might run slower than those that use the No option.
  • No: queues the message for sending, without storing a copy until the operation is complete. If a delivery error occurs when this option is No, ColdFusion generates an Application exception and logs the error to the mail.log file.

debug

Optional

No

  • Yes: sends debugging output to standard output. By default, if the console window is unavailable, ColdFusion sends output to cf_root\runtime\logs\coldfusion-out.log on server configurations. On J2EE configurations, with JRun, the default location is jrun_home/logs/servername-out.log.
    Caution: If you set this option to Yes, ColdFusion MX writes detailed debugging information to the log, including all message contents, and can generate large logs quickly.
  • No: does not generate debugging output.

Usage

Sends a mail message to the specified address. Mail messages can include attachments. The tag body can include CFML code to generate mail output. The cfmailparam and cfmailpart tags can only be used in the cfmail tag body.

Mail messages can be single or multipart. If you send a multi-part mail message, all message content must be in cfmailpart tags; ColdFusion ignores multipart message text that is not in cfmailpart tags.

Note: The cfmail tag does not make copies of attachments when spooling mail to disk. If you use the cfmail tag to send a message with an attachment with spooling enabled and you use the cffile tag to delete the attachment file, ColdFusion might not send the mail because the mailing process might execute after the file was is deleted. (When this happens, the mail log includes a FileNotFound exception and the e-mail is not sent.) You can prevent this problem by setting SpoolEnable="No" in the attribute or disabling spooling in the ColdFusion MX Administrator. Disabling spooling causes the e-mail to be delivered immediately.

Mail addressing

Mail addresses can have any of the following forms:

Format Example

user@server

[email protected]

<user@server>

<[email protected]>

DisplayName <user@server>

Rob Smith <[email protected]>

"DisplayName" <user@server>

"Rob Smith" <[email protected]>

user@server (DisplayName)

[email protected] (Rob Smith)

Specifying mail servers

The server attribute can specify one or more mail servers.

Note: If you specify multiple mail servers in ColdFusion MX Standard, the cfmail tag uses only the first server in the specification. ColdFusion logs a warning message to the mail log file and ignores the additional servers.

For each server, you can optionally specify a username, password, and port. These values override the corresponding attributes, if any. The server attribute has the following format:

[user:password@]server[:port],[user:password@]server[:port],....

For example, the following line specifies one server, mail.myco.com that uses the default port and no user or password, and a second server with a user, password, and specific port:

server=mail.myco.com,mail_admin:[email protected]:24

When you specify multiple mail servers in ColdFusion Enterprise, ColdFusion tries the available servers in the order they are listed until it connects to a server. ColdFusion does not try to connect to a server that was unavailable in the last 60 seconds.

Example

<h3>cfmail Example</h3>

<!--- Delete the surrounding comments to use this example.

<cfif IsDefined("form.mailto")>
   <cfif form.mailto is not "" 
            AND form.mailfrom is not "" 
            AND form.Subject is not "">
      <cfmail to = "#form.mailto#"
          from = "#form.mailFrom#"
          subject = "#form.subject#">
            This message was sent by an automatic mailer built with cfmail:
            = = = = = = = = = = = = = = = = = = = = = = = = = = =
            #form.body#
      </cfmail>   
      <h3>Thank you</h3>
      <p>Thank you, <cfoutput>#mailfrom#: your message, #subject#, has
            been sent to #mailto#</cfoutput>.
   </cfif>   
</cfif>
<p>
<form action = "cfmail.cfm">
   <pre>
   TO:        <input type = "Text" name = "MailTo">
   FROM: <input type = "Text" name = "MailFrom">
   SUBJECT:    <input type = "Text" name = "Subject">
   <hr>
   MESSAGE BODY:
   <textarea name ="body" cols="40" rows="5" wrap="virtual"></textarea>
   </pre>
   <!--- Establish required fields. --->
   <input type = "hidden" name = "MailTo_required" value = "You must enter
a recipient"> <input type = "hidden" name = "MailFrom_required" value = "You must
enter a sender"> <input type = "hidden" name = "Subject_required" value = "You must enter
a subject"> <input type = "hidden" name = "Body_required" value = "You must enter
some text"> <p><input type = "Submit" name = ""> </form> --->

View comments in LiveDocs