У меня есть надстройка для 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");
}
}
}
Может кто-нибудь помочь, так как нам удалось добраться до этой ошибки?Тем не менее, я понимаю, что эта ошибка обычно означает, что мы неправильно ссылались на таблицы, но тогда почему она будет работать на большинстве других машин?
Спасибо