Outlook: ссылка на объект не установлена ​​для экземпляра объекта - PullRequest
0 голосов
/ 21 октября 2011

У меня есть надстройка для Outlook (базовая отправка почты в наше приложение), которая возвращает проблему на одной машине (отлично работает на других).Это просто не работало без ошибок, поэтому мы пошли в меню SYSTEM и повернули VSTO_SUPPRESSDISPLAYALERTS = 0 для вывода на экран.

Когда я затем запустил синхронизацию, я получил следующее

Object reference not set to an instance of an object.


************** Exception Text **************
System.NullReferenceException: Object reference not set to an instance of an object.
at MyAppOutlook.WaitingPopup.btnSyncOutlookInboxMail_Click(Object sender, EventArgs e)
at System.Windows.Forms.Control.OnClick(EventArgs e)
at System.Windows.Forms.Button.OnClick(EventArgs e)
at System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
at System.Windows.Forms.Control.WndProc(Message& m)
at System.Windows.Forms.ButtonBase.WndProc(Message& m)
at System.Windows.Forms.Button.WndProc(Message& m)
at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
at System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam,     IntPtr lparam)

Я не могу понять, почему это работает на большинстве машин, но не на этом.Плагин устанавливается и появляется на панели инструментов для этого компьютера, как и другие, он просто не работает!

Я проверил и переустановил следующее, прежде чем установить наш плагин:

  • .net3.5 Framework
  • Первичные сборки взаимодействия 2007

nb Outlook 2007.

В соответствии с запросом, код для процесса выглядит следующим образом

Outlook.MAPIFolder outlookSentFolder =     (Outlook.MAPIFolder)outlookObj.Session.GetDefaultFolder(Outlook.OlDefaultFolders.olFolderSentMail);

for (int i = 1; i <= outlookSentFolder.Items.Count; i++)
{
    Outlook.MailItem mm = outlookSentFolder.Items[i] as Outlook.MailItem;
    if (mm != null)
    {
        try
        {
            DateTime StartDate = new DateTime(((Outlook.MailItem)outlookSentFolder.Items[i]).SentOn.Year, ((Outlook.MailItem)outlookSentFolder.Items[i]).SentOn.Month, ((Outlook.MailItem)outlookSentFolder.Items[i]).SentOn.Day, ((Outlook.MailItem)outlookSentFolder.Items[i]).SentOn.Hour, ((Outlook.MailItem)outlookSentFolder.Items[i]).SentOn.Minute, 0);

            if (StartDate > currentDate) // condition for current month mail sync
            {
                string attachs = "";
                for (int j = 0; j < ((Outlook.MailItem)outlookSentFolder.Items[i]).Attachments.Count; j++)
                {
                    attachs = ((Outlook.MailItem)outlookSentFolder.Items[i]).Attachments[j + 1].FileName.ToString() + "," + attachs;
                }

                ASCIIEncoding encoding = new ASCIIEncoding();
                string postData = "userDBName=" + subsDBName;
                postData += ("|MethodRequestName=addUpdateInboxMailFromOutlookToCRM");
                postData += ("|loginid=" + username);
                postData += ("|MailTo=" + ((Outlook.MailItem)outlookSentFolder.Items[i]).To);
                postData += ("|MailCC=" + ((Outlook.MailItem)outlookSentFolder.Items[i]).CC);
                postData += ("|MailFrom=" + ((Outlook.MailItem)outlookSentFolder.Items[i]).SenderEmailAddress);
                postData += ("|MailSubject=" + ((((((Outlook.MailItem)outlookSentFolder.Items[i]).Subject).Replace("|", "")).Replace("#", "")).Replace("<", "")).Replace(">", ""));
                postData += ("|MailBody=" + ((((((Outlook.MailItem)outlookSentFolder.Items[i]).Body).Replace("|", "")).Replace("#", "")).Replace("<", "")).Replace(">", ""));
                postData += ("|MailSentOn=" + StartDate.ToString("MM/dd/yyyy hh:mm:ss"));//((Outlook.MailItem)outlookSentFolder.Items[i]).SentOn.ToString());
                postData += ("|MailType=Sent");
                postData += ("|MailAttach=" + attachs);
                byte[] data = encoding.GetBytes(postData);

                // Prepare web request...
                HttpWebRequest myRequestSent = (HttpWebRequest)WebRequest.Create(reqURL + "Views/Subscription/OutlookDataService.aspx");
                myRequestSent.Method = "POST";
                myRequestSent.ContentType = "application/x-www-form-urlencoded";
                myRequestSent.ContentLength = data.Length;
                Stream newStream = myRequestSent.GetRequestStream();
                // Send the data.
                newStream.Write(data, 0, data.Length);
                newStream.Close();

                WebResponse responseHtmlSent = myRequestSent.GetResponse();
                string xmlString = "";
                using (StreamReader r = new StreamReader(responseHtmlSent.GetResponseStream()))
                {
                    xmlString = xmlString + r.ReadToEnd();
                }
                responseHtmlSent.Close();
            }
        }
        catch (Exception ex)
        {
            System.Windows.Forms.MessageBox.Show("Warning: " + ex.Message.ToString(), "Warning");
        }
    }
}

Может кто-нибудь помочь, так как нам удалось добраться до этой ошибки?Тем не менее, я понимаю, что эта ошибка обычно означает, что мы неправильно ссылались на таблицы, но тогда почему она будет работать на большинстве других машин?

Спасибо

1 Ответ

0 голосов
/ 27 октября 2011

Вы добавили блок try ... catch в свой код, когда работали над этой проблемой, или он всегда был там?

Если он всегда был там, и вы упоминаете, что Это просто не работало без ошибок тогда ошибка должна быть за пределами этого.Я бы проверил, есть ли у затронутого пользователя папка с отправленной почтой.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...