Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Create Non-Multipart Email with XML Body that is an AttachmentSee more SMTP ExamplesCreates an email where the only body is a binary WAV file. The technique used in the example could be applied to other binary files, such as PDF, MS-WORD docs, Excel docs, etc.
// Important: See this note about string length limitations for strings returned by sp_OAMethod calls. // CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- The goal of this example is to create an email that has this MIME format, -- where the body of the email is XML using base64 encoding, -- and the Content-Type and Content-Disposition are set as indicated. -- Date: Wed, 23 Aug 2023 09:01:52 +0200 (CEST) -- From: joe@example1.com -- Subject: [v=EMCS.NL][a=NL****][k=****][s=0] -- To: mary@example2.com -- MIME-Version: 1.0 -- Content-Type: application/octet-stream; charset=us-ascii; name=6bd8dfe259b3a42c90a28a82b5fc6e77.txt -- Content-Transfer-Encoding: Base64 -- Content-Disposition: attachment; filename=6bd8dfe259b3a42c90a28a82b5fc6e77.txt -- Message-Id: <......> -- -- <multi-line base64 encoded XML here> DECLARE @success int SELECT @success = 1 DECLARE @xmlBody nvarchar(4000) SELECT @xmlBody = '<ie:IE801 xmlns:ie="urn:publicid:-:EC:DGTAXUD:EMCS:PHASE4:IE801:V3.01" xmlns:tms="urn:publicid:-:EC:DGTAXUD:EMCS:PHASE4:TMS:V3.01">....</ie:IE801>' DECLARE @email int EXEC @hr = sp_OACreate 'Chilkat_9_5_0.Email', @email OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Add subject, TO, FROM, etc. EXEC sp_OASetProperty @email, 'Subject', '[v=EMCS.NL][a=NL****][k=****][s=0]' EXEC sp_OASetProperty @email, 'From', 'joe@example1.com' EXEC sp_OAMethod @email, 'AddTo', @success OUT, 'Mary', 'mary@example2.com' EXEC sp_OASetProperty @email, 'Body', @xmlBody EXEC sp_OAMethod @email, 'AddHeaderField', NULL, 'Content-Transfer-Encoding', 'Base64' EXEC sp_OAMethod @email, 'AddHeaderField', NULL, 'Content-Type', 'application/octet-stream; charset=us-ascii; name=6bd8dfe259b3a42c90a28a82b5fc6e77.txt' EXEC sp_OAMethod @email, 'AddHeaderField', NULL, 'Content-Disposition', 'attachment; filename=6bd8dfe259b3a42c90a28a82b5fc6e77.txt' -- Your email is ready to send DECLARE @mailman int EXEC @hr = sp_OACreate 'Chilkat_9_5_0.MailMan', @mailman OUT EXEC sp_OASetProperty @mailman, 'SmtpHost', 'smtp.my_mail_server.com' EXEC sp_OASetProperty @mailman, 'SmtpUsername', 'myUsername' EXEC sp_OASetProperty @mailman, 'SmtpPassword', 'myPassword' EXEC sp_OASetProperty @mailman, 'SmtpPort', 465 EXEC sp_OASetProperty @mailman, 'SmtpSsl', 1 EXEC sp_OASetProperty @mailman, 'StartTLS', 1 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!' EXEC @hr = sp_OADestroy @email EXEC @hr = sp_OADestroy @mailman END GO |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.