/// <summary>
        /// 装载邮件信息
        /// </summary>
        public SendEmailSettingInfo GetSendEmailSettingInfo()
        {
            string        str                   = "/set/customers/customer";
            string        smtpHost              = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/smtpHost");
            string        smtpPort              = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/smtpPort");
            string        emailAccount          = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/emailAccount");
            string        emailPassword         = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/emailPassword");
            string        emailRecipients       = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/emailRecipients");
            string        ccRecipients          = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/ccRecipients");
            string        lastEmailTime         = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/lastEmailTime");
            string        sendEmailCount        = XmlHelper.Read(settingPath, str + "/sendEmailSets/sendEmailSet/sendEmailCount");
            List <string> strEmailRecipientList = new List <string>();
            List <string> emailRecipientList    = emailRecipients.Split(';').ToList();

            foreach (string emailRecipient in emailRecipientList)
            {
                if (!string.IsNullOrEmpty(emailRecipient))
                {
                    strEmailRecipientList.Add(emailRecipient);
                }
            }

            List <string> strCcRecipientsList = new List <string>();
            List <string> ccRecipientsList    = ccRecipients.Split(';').ToList();

            foreach (string emailRecipient in ccRecipientsList)
            {
                if (!string.IsNullOrEmpty(emailRecipient))
                {
                    strCcRecipientsList.Add(emailRecipient);
                }
            }


            SendEmailSettingInfo sendEmailSettingInfo = new SendEmailSettingInfo()
            {
                SmtpHost           = smtpHost,
                SmtpPort           = int.Parse(smtpPort),
                EmailAccount       = emailAccount,
                EmailPassword      = emailPassword,
                EmailRecipientList = strEmailRecipientList, //电子邮件收件人列表
                CcRecipientList    = strCcRecipientsList,   //抄送收件人列表
                LastEmailTime      = Convert.ToDateTime(lastEmailTime),
                //sendEmailCount = 1
            };

            return(sendEmailSettingInfo);
        }
        /// <summary>
        /// 发送邮件
        /// </summary>
        /// <param name="richTextBox"></param>
        /// <param name="as702List"></param>
        /// <param name="factoryName"></param>
        /// <param name="recipientsList"></param>
        public bool SentEmail(List <string> attachmentPathList, SendEmailSettingInfo sendEmailSettingInfo, StringBuilder logSB, DateTime dateTime, StringBuilder tableSB)
        {
            bool flagSentEmail = true;

            try
            {
                StringBuilder emailContentSb = new StringBuilder();
                emailContentSb.Append("您好!<br><br>");
                emailContentSb.Append("**請注意:此郵件是系統自動傳送,請勿直接回覆此郵件<br><br>");
                emailContentSb.Append("以下是 <span style='font-weight:bolder;text-decoration:underline;'>NA354被拦截</span> 的訂單<br><br>");
                emailContentSb.Append(string.Format("訂單來單日期:{0}至{1}<br><br>", dateTime.AddDays(-1).ToString("yyyy年MM月dd日 09:00"), dateTime.ToString("yyyy年MM月dd日 09:00")));
                emailContentSb.AppendLine(tableSB.ToString());
                string titleInfo = "NA354拦截订单邮件提醒";


                emailContentSb.AppendLine("<br><br>");
                emailContentSb.AppendLine("<br>本邮件由系统自动发出,请不要回复,如有问题请联系IT");

                emailContentSb.Append($@"<p class=""stamp"">{DateTime.Now.ToString("yyyy年MM月dd日")}:</p>
        <hr width=""150px;"" align=""left"">
        <p class=""stamp"">HKO IT Team</p>
        <!--<img src=""img/logo.png"">-->
        <img src='' />
        <p>Disclaimer:</p>
        <p>
            This email and its attachment(s) are intended solely for the use of the individual to whom it is addressed and may
            contain information which is privileged, confidential, proprietary, or exempt from disclosure under applicable law.
            If you are not the intended recipient or the person responsible for delivering the message to the intended
            recipient, you are strictly prohibited from disclosing, distributing, copying, or in any way using this message. If
            you have received this email in error, please notify the sender and destroy / delete any copies you may have
            received.
        </p>");

                EmailHelper.SendMail("HK-IT", sendEmailSettingInfo.EmailAccount, sendEmailSettingInfo.EmailPassword, sendEmailSettingInfo.EmailRecipientList, sendEmailSettingInfo.CcRecipientList, string.Format("{0}", titleInfo), emailContentSb.ToString(), attachmentPathList, sendEmailSettingInfo.SmtpHost, sendEmailSettingInfo.SmtpPort, false);
            }
            catch (Exception ex)
            {
                logSB.AppendLine(ex.Message);
                flagSentEmail = false;
            }
            return(flagSentEmail);
        }
Пример #3
0
        static void Main(string[] args)
        {
            StringBuilder sbLog    = new StringBuilder(); //可变的字符串
            DateTime      dateTime = DateTime.Now;        //获取当前的日期

            sbLog.AppendLine(string.Format("数据开始解析,当前时间为:{0}", dateTime.ToString("yyyy-MM-dd HH:mm:ss")));

            string beginTime = dateTime.AddDays(-1).ToString("yyyy-MM-dd 09:00:00");
            string endTime   = dateTime.ToString("yyyy-MM-dd 09:00:00");

            OperationServer operationServer = new OperationServer(settingPath);

            sbLog.AppendLine(string.Format("开始创建文价夹"));
            string excelPath = Path.Combine(startupPath, @"Result\Excel\");
            string logPath   = Path.Combine(startupPath, @"Result\Log\");

            try
            {
                operationServer.CreateDirectory(excelPath);
                operationServer.CreateDirectory(logPath);
                sbLog.AppendLine(string.Format("文价夹创建成功"));

                SendEmailSettingInfo   sendEmailSettingInfo   = operationServer.GetSendEmailSettingInfo();
                DatabaseSetSettingInfo databaseSetSettingInfo = operationServer.GetDatabaseSetSettingInfo();

                SqlHelper sqlHelper = new SqlHelper(dbHost: databaseSetSettingInfo.dbHost, dbName: databaseSetSettingInfo.dbName, dbUser: databaseSetSettingInfo.dbUser, dbPwd: databaseSetSettingInfo.dbPwd);

                DataTable dataTable = operationServer.GetDataTable(sqlHelper, beginTime, endTime, true);
                sbLog.AppendLine(string.Format("数据获取成功,共有{0}条", dataTable.Rows.Count));

                string excelFilePath = string.Empty;
                if (dataTable != null && dataTable.Rows.Count > 0)
                {
                    excelFilePath = Path.Combine(excelPath, string.Format("NA354_{0}_{1}_{2}_拦截单.xlsx", dateTime.ToString("yyyy"), dateTime.ToString("MM"), dateTime.ToString("dd")));
                    NPOIHelper npoiHelper = new NPOIHelper();
                    npoiHelper.ExportDataTableToExcel(dataTable, excelFilePath);
                    sbLog.AppendLine(string.Format("Excel生成成功,路径为{0}", excelFilePath));
                }

                if (!string.IsNullOrEmpty(excelFilePath))
                {
                    StringBuilder tableSB = new StringBuilder();
                    tableSB.AppendLine("<table border='1' cellspacing='0' cellpadding='0' style='text-align:center;'>");
                    tableSB.AppendLine("<tr style='background-color:#5b9bd5'>" +
                                       "<th width='300px'>deposit_number</th>" +
                                       "<th width='350px'>wo_number</th>" +
                                       "<th width='200px'>type</th>" +
                                       "<th width='200px'>status</th>" +
                                       "<th width='300px'>ref_num</th>" +
                                       "<th width='200px'>in_param</th>" +
                                       "<th width='300px'>err_msg</th>" +
                                       "<th width='300px'>updated_on</th>" +
                                       "</tr>");
                    if (dataTable.Rows.Count > 0)
                    {
                        foreach (DataRow row in dataTable.Rows)
                        {
                            tableSB.AppendLine(string.Format("<tr><td>{0}</td><td>{1}</td>" +
                                                             "<td>{2}</td>" +
                                                             "<td>{3}</td>" +
                                                             "<td>{4}</td>" +
                                                             "<td>{5}</td>" +
                                                             "<td>{6}</td>" +
                                                             "<td>{7}</td></tr>",
                                                             row["deposit_number"].ToString(),
                                                             row["wo_number"].ToString(),
                                                             row["type"].ToString(),
                                                             row["status"].ToString(),
                                                             row["ref_num"].ToString(),
                                                             row["in_param"].ToString(),
                                                             row["err_msg"].ToString(),
                                                             row["updated_on"].ToString()));
                        }
                    }
                    tableSB.AppendLine($"</table");
                    sbLog.AppendLine(string.Format("Table拼接成功"));

                    bool flagSentEmail = operationServer.SentEmail(new List <string>()
                    {
                        excelFilePath
                    }, sendEmailSettingInfo, sbLog, dateTime, tableSB);
                    sbLog.AppendLine(string.Format("发送邮件{0}", flagSentEmail ? "成功" : "失败"));
                }
            }
            catch (Exception ex)
            {
                sbLog.AppendLine(string.Format("发送错误:{0}", ex.Message));
            }

            string logFilePath = Path.Combine(logPath, "Log_" + dateTime.ToString("yyyyMMddHHmmss") + ".TXT");

            TxtHelper.Write(logFilePath, sbLog.ToString());
        }