Learn how to a build a cloud-first strategyRegister Now

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 806
  • Last Modified:

Extract Attachment from Exchange server in C# VS 2008

Hi there,

this sounds simple, but after googling to much my head has gone google.

I need to write a service that will scan an email box for new emails and pull out the attachments. The I will unzip them and process them. Sounds simple.

I have use .net to send emails but never to attach to an inbox and check for emails.

What is the simplest and easy way to do this... bearing in mind that the email account will be in my organisation that uses Outlook. I have seen some people use 3rd party POP3 libaries etc but surely this can be done by straight forward .net libaries.

I was going to test this by connecting to my own account and testing so any sample code on this would be great.

Much appreciated.. mick
0
MickyMc
Asked:
MickyMc
  • 4
  • 2
  • 2
2 Solutions
 
Éric MoreauSenior .Net ConsultantCommented:
0
 
MickyMcAuthor Commented:
thanks emoreau..

I put some code together and just curious why you dont use the Interop.Outlook like below

        private void btnConnect_Click(object sender, EventArgs e)
        {
            Outlook.Application outlook = new Outlook.ApplicationClass();
            Outlook.NameSpace ns = outlook.GetNamespace("Mapi");

            object _missing = Type.Missing;
            ns.Logon(_missing, _missing, false, true);


            Outlook.MAPIFolder inbox = ns.GetDefaultFolder(Outlook.OlDefaultFolders.olFolderInbox);

            int unread = inbox.UnReadItemCount;

            foreach (Outlook.MailItem mail in inbox.Items)
            {
                String subject;

                if (mail.Attachments.Count > 0)
                {
                    if (mail.Subject.Length > 20)
                        subject = mail.Subject.Substring(0, 20) + "..";
                    else
                        subject = mail.Subject;

                    dgvEmails.Rows.Add(mail.SenderName, subject, mail.ReceivedTime, mail.UnRead, mail.Attachments.Count);
                    dgvEmails.Refresh();
                    Application.DoEvents();
                }
            }                        
        }

Open in new window


I'm just reading through my outlook inbox and putting the results in a grid. However I get an exception on this for loop..
foreach (Outlook.MailItem mail in inbox.Items)

Open in new window

It tells me invalid cast... but it works for most mails and only throws an exception on some... any ideas
0
 
MickyMcAuthor Commented:
OK so it seems that when you iterate through the MailItems there can be Calendar items in your inbox and when you try to cast them... Exception.

Instead you have to iteratie through all the items and try and cast them to an Mail Item.

So back to the question ... is this the best approach  
0
Problems using Powershell and Active Directory?

Managing Active Directory does not always have to be complicated.  If you are spending more time trying instead of doing, then it's time to look at something else. For nearly 20 years, AD admins around the world have used one tool for day-to-day AD management: Hyena. Discover why

 
Robberbaron (robr)Commented:
if you are using Exchange 2007 & 2010, the the EWS API is quite easy to use. http://msdn.microsoft.com/en-us/library/dd637749(EXCHG.80).aspx


0
 
MickyMcAuthor Commented:
robberbaron, you could be on the money here. This actually looks good. My only beef is that I cant see how I can specify an email server and login details. I used Interop.Outlook and found that it takes the creditentials from the client Outlook on my destop and just ignores the login creditentials in the api. I took emoreau advice and used http://www.lesnikowski.com/mail/  which is a great little application for the price. I could specify the server and get different users to login into their accounts and pull back the emails. However I'm not sure if my company will allow 3rd party controls to be used other than Microsoft.

So if you can let me know if this supports connections to various exchange servers with differential creditals the points are yours..
0
 
Éric MoreauSenior .Net ConsultantCommented:
what do you want to do exactly? if you login using different credentials, yes you will be able to access what those credentials gives you access to.
0
 
Robberbaron (robr)Commented:
can certainly connect using various credentials.

All of my coding has been against PublicFolders, where i use a "service account" that can access the entire store.
But impersonation is available too.

see http://msdn.microsoft.com/en-us/library/dd633680%28EXCHG.80%29.aspx for both options.
 This links to the EWS documentation that has a number of useful examples.
0
 
MickyMcAuthor Commented:
thanks Gents, I'm splitting the points as both answers where of great help so it comes down to a matter of preference. Thanks for all your help...

regards Mick
0

Featured Post

Has Powershell sent you back into the Stone Age?

If managing Active Directory using Windows Powershell® is making you feel like you stepped back in time, you are not alone.  For nearly 20 years, AD admins around the world have used one tool for day-to-day AD management: Hyena. Discover why.

  • 4
  • 2
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now