1

以前の質問を参照して、私はすでにプログラムを作成しており、実行に VS2008 を使用しているときに素晴らしい動作をしています。

さらに 2 つの質問があります。

1.プログラムを実行したときに、すべてのメールが VS 出力に xml ファイルとして表示されることを確認したいのですが、出力に印刷することはありませんでした。それはすべての人にとって通常のことですか、それとも削除するために何かを追加する必要があります。PC からメールが出力されるまでに時間がかかるように感じます。

2.私の2番目の質問は、exeファイルのみをスタンドアロンで使用したい場合(VSではなくexeファイルを介してプログラムを実行する)、以下のエラーが発生し、プログラムがハングして閉じることです。

「問題が発生したため、MailReader を終了する必要があります。ご迷惑をおかけして申し訳ありません。」

上で述べたように、このプログラムは VS で正常に動作しています。

メールを読むコードの一部をコピーし、参照用に分割します。

public void ReadMail()
        {
            ServicePointManager.ServerCertificateValidationCallback += delegate(object sender,
                                                                                X509Certificate certificate,
                                                                          X509Chain chain,
                                                                                SslPolicyErrors sslPolicyErrors) { return true; };
            try
            {
                ExchangeService service = new ExchangeService(ExchangeVersion.Exchange2007_SP1);
                service.TraceEnabled = true;
                service.Credentials = new WebCredentials(_username, _password); //Modify this
                service.Url = new Uri(_exchange); //Modify this
                service = new ExchangeService(ExchangeVersion.Exchange2007_SP1);

                service.Url = new Uri(_exchange);
                service.TraceEnabled = true;
                service.Credentials = new WebCredentials(_username, _password); //Modify this
                service.Url = new Uri(_exchange);
                //SearchFilter to get unreaded messages only.
                SearchFilter sf = new SearchFilter.SearchFilterCollection(LogicalOperator.And, new SearchFilter.IsEqualTo(EmailMessageSchema.IsRead, false));
                ItemView itemview = new ItemView(Int16.MaxValue);


                //DateTime searchdate = new DateTime(2012, 7, 6); //Year, month, day
                SearchFilter greaterthanfilter = new SearchFilter.IsGreaterThan(ItemSchema.DateTimeSent, Convert.ToDateTime(startDate));
                SearchFilter lessthanfilter = new SearchFilter.IsLessThan(ItemSchema.DateTimeSent,Convert.ToDateTime(finishDate));
                SearchFilter[] f = { greaterthanfilter, lessthanfilter };
                SearchFilter filter = new SearchFilter.SearchFilterCollection(LogicalOperator.And, f);
                //Folder folder = Folder.Bind(this.m_Service, WellKnownFolderName.MsgFolderRoot); //Or the folder you want to search in
                //FindItemsResults<Item> results = folder.FindItems(filter, new ItemView(1000));


                FindItemsResults<Item> findResults = service.FindItems(WellKnownFolderName.SentItems,filter, itemview);

                Action action = () => fr.setText(findResults.Items.Count + "mails need to analysis from "+startDate +" to "+ finishDate);
                fr.Invoke(action, null);

                action = () => fr.setMaximumProgressBar(findResults.Items.Count);
                fr.Invoke(action, null);

                dmd = new List<DailyMailDetails>();

                foreach (Item item in findResults.Items)
                {
                    string messageDate = "Error in Date";
                    string messageSubj = "Error in Subject";
                    int index = 0; 
                    try
                    {
                        PropertySet propertySet = new PropertySet(BasePropertySet.FirstClassProperties, ItemSchema.DateTimeSent, ItemSchema.Body, ItemSchema.Subject);
                        propertySet.RequestedBodyType = BodyType.Text;
                        EmailMessage message = EmailMessage.Bind(service, item.Id, propertySet);

                        string temp = startSign.ToUpper();
                        int start = message.Body.Text.ToUpper().IndexOf(temp) + temp.Length;
                        int end = message.Body.Text.ToUpper().IndexOf(finishSign.ToUpper());
                        int len = end - start;
                        string text = message.Body.Text.Substring(start, len);

                        index = findDmdIndex(message.DateTimeSent.ToShortDateString().ToString());

                        if (index == -1)
                        {
                            dmd.Add(new DailyMailDetails(message.DateTimeSent.ToShortDateString().ToString(), (List<PeopleSigniture>)Extensions.Clone<PeopleSigniture>(OrginallistPeopleSign)));
                            index = dmd.Count - 1;
                        }
                        bool signExist = false;

                        for (int i = 0; i < listPeopleSign.Count; i++)
                            if (text.ToUpper().Contains(dmd[index].peopleSign[i].Signiture.ToUpper()))
                            {
                                dmd[index].peopleSign[i].addResponse(message.DateTimeSent.ToString(), message.Subject.ToString());
                                signExist = true;
                                break;
                            }
                        messageDate = message.DateTimeSent.ToString();
                        messageSubj = message.Subject.ToString();
                        if (!signExist)
                            dmd[index].peopleSign[dmd[index].peopleSign.Count - 2].addResponse(message.DateTimeSent.ToString(), message.Subject.ToString());
                    }
                    catch (Exception ex)
                    {
                        dmd[index].peopleSign[dmd[index].peopleSign.Count - 1].addResponse(messageDate, messageSubj);
                    }


                    action = () => fr.increasePrograss();
                    fr.Invoke(action, null);
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show("Class: Mail Function:ReadMail" + ex.Message);
            }
            Action action2 = () => fr.setText(ToString(true),dmd);
            fr.Invoke(action2, null);
        }
4

1 に答える 1

1

問題 1 については、 EWS トレースが有効になっているため、XML 出力が表示されている可能性があります。ExchangeService.TraceEnabledに設定するfalseか、完全にコメントアウトする必要があります。(クリーンアップが必要なコードの重複行も多数あります。 )

service.TraceEnabled = false;

問題 2 については、実際の .NET 例外を特定する必要があります。これがなければ、これ以上お手伝いすることはできません。無数の理由でクラッシュする可能性があります。スタック トレースを提供してください。

于 2013-06-27T01:55:28.317 に答える