Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to use razor engine for email templating with image src

I've found this link on how to using Razor Engine for email templates in asp.net and it worked great. But I've tried to have a logo in the email template with an image.

Something like this:

EmailTemplate.cshtml (this by the way is a strongly-type view)

<html>
<body>
  <img src="logo.jpg" />
</body>
</html>

and when I try to submit it on email, it seems that the image path was not read, it only rendered an X in the content.

I'm thinking to pass the image path as part of the Model but it seems odd that way. Is there any way to achieve this?

Any help would be much appreciated. Thanks

like image 642
Boy Pasmo Avatar asked Sep 24 '15 17:09

Boy Pasmo


People also ask

Is razor a template engine?

Razor is a templating engine that was introduced with ASP.NET MVC, originally to run on the server and generate HTML to be served to web browsers. The Razor templating engine extends standard HTML syntax with C# so that you can express the layout and incorporate CSS stylesheets and JavaScript easily.

What is razor pages web app?

Razor Pages is designed to make common patterns used with web browsers easy to implement when building an app. Model binding, Tag Helpers, and HTML helpers work with the properties defined in a Razor Page class.


1 Answers

To see image everywhere you can use these options:

Absolute Url

You can simply use full absolute path of image for example "http://example.com/images/logo.png"

IMO It is the most simple option and recommended for your problem.

Attachment

As mentioned by Mason in comments You can attach image to mail and then put image tag and useContentId of attachment:

//(Thanks to Mason for comment and Thanks to  Bartosz Kosarzyck for sample code)
string subject = "Subject";
string body = @"<img src=""$CONTENTID$""/> <br/> Some Content";

MailMessage mail = new MailMessage();
mail.From = new MailAddress("[email protected]");
mail.To.Add(new MailAddress("[email protected]"));
mail.Subject = subject;
mail.Body = body;
mail.Priority = MailPriority.Normal;

string contentID = Guid.NewGuid().ToString().Replace("-", "");
body = body.Replace("$CONTENTID$", "cid:" + contentID);

AlternateView htmlView = AlternateView.CreateAlternateViewFromString(body, null, "text/html");
//path of image or stream
LinkedResource imagelink = new LinkedResource(@"C:\Users\R.Aghaei\Desktop\outlook.png", "image/png");
imagelink.ContentId = contentID;
imagelink.TransferEncoding = System.Net.Mime.TransferEncoding.Base64;
htmlView.LinkedResources.Add(imagelink);
mail.AlternateViews.Add(htmlView);

SmtpClient client = new SmtpClient();
client.Host = "mail.example.com";
client.Credentials = new NetworkCredential("[email protected]", "password");
client.Send(mail);

Data Uri

you can use data uri (data:image/png;base64,....).

Not Recommended because of weak support in most of mail clients, I tested it with Outlook.com(web) and OutlookWebAccess(web) and Office Outlook(Windows) and Outlook(windows 8.1) and unfortunately it worked only on OutlookWebAccess(web).

like image 51
Reza Aghaei Avatar answered Sep 28 '22 05:09

Reza Aghaei