Click here to Skip to main content
15,881,882 members
Articles / Web Development / ASP.NET

Embed image in Email - ASP.NET , C#

Rate me:
Please Sign up or sign in to vote.
3.05/5 (23 votes)
13 Dec 2007CPOL1 min read 275.4K   45   39
Code to embed logo and other images while sending email

Introduction

This is a simple article which tells you how you can embed images in emails. This can be very useful when you want to send emails from your website.A common scenario would be when a new user registers with your site and you want to send a welcome email with your site's logo on top.

I searched the net when I faced this issue. I am grateful to many authors from where I could make a start. I have used their code while writing this. Due credit goes to them all. The intention is to make the code available for the others too. To use this all you have to so is copy the code and paste it in any button click event.

This may only work with ASP.NET 2.0 & C#. I have tested it too. It will not run in ASP.NET 1.1.

Namespaces Used

C#
using System.Net.Mail;
using System.Net.Mime;

Code

// send mail to the new user who has registered.
  protected void yourButton_Click(object sender, EventArgs e)
   {

           string strMailContent = "Welcome new user";
           string fromAddress = "yourname@yoursite.com";
           string toAddress = "newuser@hisdomain.com";
           string contentId  = "image1";
           string path = Server.MapPath(@"images/Logo.jpg"); // my logo is placed in images folder
           MailMessage mailMessage = new MailMessage( fromAddress, toAddress );
           mailMessage.Bcc.Add("inkrajesh@hotmail.com"); // put your id here
           mailMessage.Subject = "Welcome new User";

           LinkedResource logo = new LinkedResource(path);
           logo.ContentId = "companylogo";
           // done HTML formatting in the next line to display my logo
           AlternateView av1 = AlternateView.CreateAlternateViewFromString("<html><body><img src=cid:companylogo/><br></body></html>" + strMailContent, null, MediaTypeNames.Text.Html);
           av1.LinkedResources.Add(logo);

           mailMessage.AlternateViews.Add(av1);
           mailMessage.IsBodyHtml = true;
           SmtpClient mailSender = new SmtpClient("localhost"); //use this if you are in the development server
                       mailSender.Send(mailMessage);

       }

Note: SmtpClient mailSender = new SmtpClient(ConfigurationManager.AppSettings["MyCustomId"]); // use this in the Production Server. I have specified my email server in the web.config file

Remarks

The image may not be displayed in Outlook Express. It worked well when the mail was viewed in Yahoo. If your site is not a trusted one there is a chance that the image may be blocked. It did not work with Hotmail and Gmail.

There are other ways to show images, but like many authors have pointed out they do not embed the image. They always refer to the parent site. The image won't be displayed when offline or when the location of the image has changed in the parent site

Do please send your comments . I would be happy to hear from you.

Thank you , Happy Coding !

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Web Developer
India India
A Mechanical Engineer, MBA working in Microsoft Technologies. Currently employed with a software major in Mumbai,India

Comments and Discussions

 
QuestionImage stream attachments? Pin
PSU Mike7-Aug-08 5:00
PSU Mike7-Aug-08 5:00 
Generaldo not work with outlook 2007 Pin
mrodrig@renacimiento.com24-Jul-08 1:06
mrodrig@renacimiento.com24-Jul-08 1:06 
GeneralRe: do not work with outlook 2007 Pin
KenL_MCSE31-Oct-08 7:24
KenL_MCSE31-Oct-08 7:24 
GeneralRe: do not work with outlook 2007 Pin
Member 435949310-Dec-08 20:17
Member 435949310-Dec-08 20:17 
GeneralRe: do not work with outlook 2007 Pin
MaciusA28-Apr-10 22:17
MaciusA28-Apr-10 22:17 
GeneralRe: do not work with outlook 2007 Pin
shivam.mehta22-Nov-16 7:09
shivam.mehta22-Nov-16 7:09 
GeneralAdd Button in Email Pin
Dnyaneshwar Kubal4-Mar-08 1:54
professionalDnyaneshwar Kubal4-Mar-08 1:54 
GeneralRe: Add Button in Email Pin
Rajesh C Medackel12-Mar-08 2:03
Rajesh C Medackel12-Mar-08 2:03 
Hi Dyno,

It can be due to the security settings. Please check the message displayed and act accordingly.

You can also check the version of the Outlook

Rajesh Smile | :)
GeneralVery good article Pin
a-tibi27-Nov-07 2:44
a-tibi27-Nov-07 2:44 
QuestionAdding Text after Image Pin
Sheila K26-Jul-07 9:08
Sheila K26-Jul-07 9:08 
Questionimage going as attachement Pin
DilipV26-Jun-07 6:40
DilipV26-Jun-07 6:40 
AnswerRe: image going as attachement Pin
DilipV26-Jun-07 7:06
DilipV26-Jun-07 7:06 
Questionhow to send mail using outlook express 9.0 (asp.net 2.0)? Pin
Jesu.Official14-Feb-07 17:08
Jesu.Official14-Feb-07 17:08 
GeneralPost Code Pin
laokimsea5-Jan-07 19:24
laokimsea5-Jan-07 19:24 
GeneralRe: Post Code Pin
Rajesh C Medackel29-Jan-07 3:01
Rajesh C Medackel29-Jan-07 3:01 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.