Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Example to Add Several BCC Email RecipientsSee more Email Object ExamplesDemonstrates how to call AddBCC once per email recipient.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) DECLARE @email int -- Use "Chilkat_9_5_0.Email" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Email', @email OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int EXEC sp_OASetProperty @email, 'Subject', 'Test email subject' EXEC sp_OASetProperty @email, 'Body', 'Test email body' EXEC sp_OASetProperty @email, 'From', 'Test <joe@example.com>' -- Add a primary TO recipient EXEC sp_OAMethod @email, 'AddTo', @success OUT, 'Elizabeth', 'elizabeth@example.com' -- Add a CC recipient. EXEC sp_OAMethod @email, 'AddCC', @success OUT, 'Jerry', 'jerry@example.com' -- Add 2 BCC recipients. EXEC sp_OAMethod @email, 'AddBcc', @success OUT, 'Mira', 'mira@example.com' EXEC sp_OAMethod @email, 'AddBcc', @success OUT, 'Alexander', 'alex@example.com' -- BCC recipients will not be present in the MIME of the email that is sent. -- However, the BCC recipients are included in the recipients provided to the SMTP server -- during the SMTP protocol conversation. This will be shown below. -- First, let's look at the MIME. EXEC sp_OAMethod @email, 'GetMime', @sTmp0 OUT PRINT @sTmp0 -- MIME-Version: 1.0 -- Date: Sat, 30 Oct 2021 07:58:32 -0500 -- Message-ID: <183D5F51163BE4374B494D2ED067DE2783CC761B@SLICE> -- Content-Type: text/plain; charset=us-ascii; format=flowed -- Content-Transfer-Encoding: 7bit -- X-Priority: 3 (Normal) -- Subject: Test email subject -- From: Test <joe@example.com> -- CKX-Bounce-Address: joe@example.com -- To: Elizabeth <elizabeth@example.com> -- Cc: Jerry <jerry@example.com> -- -- Test email body -- Notice that the BCC recipients do not appear in the MIME. But don't worry, they are still present within the email object. -- The difference between CC and BCC recipients is that CC recipients appear in the MIME. Thus, the recipient of the email -- can see the CC recipients, but cannot see and is unaware of the BCC recipients. -- -- Note: You may notice the "CKX-Bounce-Address" header. This is a header that appears in the MIME -- -- but is automatically removed when a Chilkat method to send email is called. -- -- Chilkat automatically removes all headers beginning with "CKX-" when sending email. -- ---------------------------------------------------------------------------------------------- -- Let's send the above email and examine the SMTP session log to show that the BCC recipients also receive the email. DECLARE @mailman int -- Use "Chilkat_9_5_0.MailMan" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.MailMan', @mailman OUT EXEC sp_OASetProperty @mailman, 'SmtpHost', 'smtp.example.com' EXEC sp_OASetProperty @mailman, 'SmtpUsername', 'myUsername' EXEC sp_OASetProperty @mailman, 'SmtpPassword', 'myPassword' EXEC sp_OASetProperty @mailman, 'SmtpSsl', 1 EXEC sp_OASetProperty @mailman, 'SmtpPort', 465 EXEC sp_OAMethod @mailman, 'SendEmail', @success OUT, @email IF @success <> 1 BEGIN EXEC sp_OAGetProperty @mailman, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @email EXEC @hr = sp_OADestroy @mailman RETURN END EXEC sp_OAMethod @mailman, 'CloseSmtpConnection', @success OUT IF @success <> 1 BEGIN PRINT 'Connection to SMTP server not closed cleanly.' END PRINT 'Mail Sent!' -- Examine the SMTP session log. EXEC sp_OAGetProperty @mailman, 'SmtpSessionLog', @sTmp0 OUT PRINT @sTmp0 -- Here you can see the session log and the BCC email addresses included in the "RCPT TO" commands. -- 220 smtp.example.com ESMTP Example SMTP Service -- EHLO SLICE<CRLF> -- 250-smtp.example.com -- 250-8BITMIME -- 250-AUTH PLAIN LOGIN -- 250 Ok -- AUTH LOGIN<CRLF> -- 334 VXNlcm5hbWU6 -- ***<CRLF> -- 334 UGFzc3dvcmQ6 -- {PasswordOrCredentials} -- 235 Authentication successful. -- MAIL FROM:<joe@example.com><CRLF> -- 250 Ok -- RCPT TO:<elizabeth@example.com><CRLF> -- 250 Ok -- RCPT TO:<jerry@example.com><CRLF> -- 250 Ok -- RCPT TO:<mira@example.com><CRLF> -- 250 Ok -- RCPT TO:<alex@example.com><CRLF> -- 250 Ok -- DATA<CRLF> -- 354 End data with <CR><LF>.<CR><LF> -- {388 bytes} -- <CRLF>.<CRLF> -- 250 Ok -- QUIT<CRLF> -- 221 Bye EXEC @hr = sp_OADestroy @email EXEC @hr = sp_OADestroy @mailman END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.