VBScript Scripting Techniques > Network > Send e-Mail
CDOSYS | |
---|---|
VBScript Code: | |
WScript.Echo EMail( "John Doe <john@home.now>", _ "Jane Doe <jane@work.now>", _ "Hi", _ "Miss you!" & vbCrLf & "Love, John", _ "", _ "", _ "smtp.home.now", _ 25 ) Function EMail( myFrom, myTo, mySubject, myTextBody, myHTMLBody, myAttachment, mySMTPServer, mySMTPPort ) ' This function sends an e-mail message using CDOSYS ' ' Arguments: ' myFrom = Sender's e-mail address ("John Doe <jdoe@mydomain.org>" or "jdoe@mydomain.org") ' myTo = Receiver's e-mail address ("John Doe <jdoe@mydomain.org>" or "jdoe@mydomain.org") ' mySubject = Message subject (optional) ' myTextBody = Actual message (text only, optional) ' myHTMLBody = Actual message (HTML, optional) ' myAttachment = Attachment as fully qualified file name, either string or array of strings (optional) ' mySMTPServer = SMTP server (IP address or host name) ' mySMTPPort = SMTP server port (optional, default 25) ' ' Returns: ' status message ' ' Written by Rob van der Woude ' http://www.robvanderwoude.com ' Standard housekeeping Dim i, objEmail ' Use custom error handling On Error Resume Next ' Create an e-mail message object Set objEmail = CreateObject( "CDO.Message" ) ' Fill in the field values With objEmail .From = myFrom .To = myTo ' Other options you might want to add: ' .Cc = ... ' .Bcc = ... .Subject = mySubject .TextBody = myTextBody .HTMLBody = myHTMLBody If IsArray( myAttachment ) Then For i = 0 To UBound( myAttachment ) .AddAttachment Replace( myAttachment( i ), "\", "\\" ),"","" Next ElseIf myAttachment <> "" Then .AddAttachment Replace( myAttachment, "\", "\\" ),"","" End If If mySMTPPort = "" Then mySMTPPort = 25 End If With .Configuration.Fields .Item( "http://schemas.microsoft.com/cdo/configuration/sendusing" ) = 2 .Item( "http://schemas.microsoft.com/cdo/configuration/smtpserver" ) = mySMTPServer .Item( "http://schemas.microsoft.com/cdo/configuration/smtpserverport" ) = mySMTPPort .Update End With ' Send the message .Send End With ' Return status message If Err Then EMail = "ERROR " & Err.Number & ": " & Err.Description Err.Clear Else EMail = "Message sent ok" End If ' Release the e-mail message object Set objEmail = Nothing ' Restore default error handling On Error Goto 0 End Function |
|
Requirements: | |
Windows version: | 2000, XP, Server 2003, or Vista |
Network: | any |
Client software: | N/A |
Script Engine: | any |
Summarized: | Works in Windows 2000 or later. Won't work in Windows 95, 98, ME, or NT 4. |
Related links: | Sending e-mail with CDOSYS E-mails generated by batch files Automate reading Outlook mail |
[Back to the top of this page] |
page last modified: 2016-09-19; loaded in 0.0014 seconds