关于在ASP.net中页面加载时清除队列

本文关键字:加载 清除 队列 ASP net | 更新日期: 2023-09-27 18:17:35

我试图用用户的邮件填充队列,以便在一段时间后向他们发送确认邮件,因此每次任何用户填写他的注册表单时,我都会将他添加到队列中,以便在大约一分钟后向他们发送邮件,下面是我的代码

public static class Gmail
    {
        private static int ? date;
        public static bool SendMail(string AdminMail,string AdminPassword,string subject,string toAddress, string content,DateTime SendTime)
        {
            var toAddressList = new Queue<string>();
            toAddressList.Enqueue(toAddress);
            if(date==null)
            {
                date = DateTime.Now.Second;
            }
            if (date-SendTime.Second > 120)
            {
                    var message = new MailMessage
                                      {
                                          From = new MailAddress(AdminMail)
                                      };
                    foreach (var toAddressl in toAddressList)
                    {
                        message.To.Add(new MailAddress(toAddressl));
                    }
                    message.Subject = subject;
                    message.Body = content;
                    message.IsBodyHtml = true;
                    var smtp = new SmtpClient
                                   {
                                       Credentials = new System.Net.NetworkCredential(AdminMail, AdminPassword),
                                       Port = 587,
                                       Host = "smtp.gmail.com",
                                       EnableSsl = true
                                   };
                    smtp.Send(message);
                //date = SendTime;
                return true;
            }
            return false;
        }
    }

,但实际情况是队列每次都从零开始,所以它只包含当前注册用户的邮件,而不包含我希望他们存在的以前注册用户的邮件,因为我将向队列中存在的所有邮件发送邮件。所以我想知道如何防止队列被清除时,页面加载。有什么想法?

关于在ASP.net中页面加载时清除队列

toAddress用静态方法的作用域定义。它将只在该方法调用期间存在。这就是为什么它总是0。

你可以把它推到一个静态字段或属性(即与你的日期属性一起),但你仍然会有这个问题;例如,如果应用程序池被回收或网站重新启动怎么办?你会失去队列中的所有东西。

一个更健壮的设计应该包括将这些信息存储在数据库中,并对那些最近添加的并且没有"confirm email sent"列值集的记录运行定期检查,例如