Skip to main content

How to send email messages with attachments

Sending E-mail messages from Microsoft Dynamics AX could be a bit tricky.
As I mentioned in a following blog post, the most recommended way to do so is by using the standard mail mechanism built in the system.The Email sending status form (based on table SysOutgoingEmailTable) and the E-mail distributor batch job (read more about it here).
But if you want to send email with attachments and more advance options, you should do so with .NET Framework, and the System.Net.Mail object.
First of all, make sure you have a correctly configured SMTP server.
Go to Administration -> Setup -> E-mail parameters and fill the required settings:
(Form: SysEmailParameters)
Then, use this code sample:
void SendMail()
{

System.Net.Mail.MailMessage mailMessage;
System.Net.Mail.Attachment attachment;
System.Net.Mail.AttachmentCollection attachementCollection;
System.Net.Mail.SmtpClient smtpClient;
System.Net.Mail.MailAddress mailAddressFrom;
System.Net.Mail.MailAddress mailAddressTo;
str Body;
str Subject;
str SMTPServer;
str FileName;
FileIOPermission perm;
;

mailAddressFrom = new System.Net.Mail.MailAddress("From@xPlusPlus.info","");
mailAddressTo = new System.Net.Mail.MailAddress("To@xPlusPlus.info","");
Body = "Body of the email";
Subject = "Subject line for the email";
SMTPServer = SysEmailParameters::find(false).SMTPRelayServerName;

mailMessage = new System.Net.Mail.MailMessage(mailAddressFrom, mailAddressTo);
mailmessage.set_Subject(Subject);
mailmessage.set_Body(Body);
attachementCollection = mailMessage.get_Attachments();

// Add attachemnts! use double slashes ("\") in the filename path.
FileName = "C:\\test.bmp";
perm = new FileIOPermission(FileName,'w');
perm.assert();

attachment = new System.Net.Mail.Attachment(FileName);
attachementCollection.Add(attachment);
smtpClient = new System.Net.Mail.SmtpClient(SMTPServer);
smtpClient.Send(mailmessage);

CodeAccessPermission::revertAssert();
}

Popular posts from this blog

Dynamics Axapta: Sales Orders & Business Connector

Well, again folllowing my same idea of writting close to nothing and pasting code, I'll paste in some code to create a sales order from some basic data and the invoice it. I'll try to explain more in the future. AxaptaObject axSalesTable = ax.CreateAxaptaObject("AxSalesTable"); AxaptaRecord rcInventDim = ax.CreateAxaptaRecord("InventDim"); AxaptaRecord rcCustTable = ax.CreateAxaptaRecord("CustTable"); rcCustTable.ExecuteStmt("select * from %1 where %1.AccountNum == '" + MySalesOrderObject.CustAccount + "'"); if (MySalesOrderObject.CurrencyCode.Trim().Length == 0) MySalesOrderObject.CurrencyCode = rcCustTable.get_Field("Currency").ToString().Trim(); string sTaxGroup = rcCustTable.get_Field("taxgroup").ToString().Trim(); //set header level fields axSalesTable.Call("parmSalesName", MySalesOrderObject.SalesName.Trim()); axSalesTable.Call("parmCustAccount", M

Passing values between form and class

Class name is EmplDuplication and Form is EmplTable . void clicked() {    MenuFunction mf;    args args = new Args();    ;     args.record(EmplTable);     mf = new menufunction(identifierstr(EmplDuplication), MenuItemType::Action); mf.run(args); } Meanwhile, in the main() method of the EmplDuplication class, we need to put this Axapta x++ code to get the datasource: static void main(Args args) {     EmplDuplication EmplDuplication; EmplTable localEmplTable; ;     if(args.record().TableId == tablenum(EmplTable)) localEmplTable = args.record();     ... }