private void BatchSendEmail_Click(object sender, EventArgs e) { #region 批量发送邮件 if (this.CheckCookie()) { groupidlist = Usergroups.GetSelectString(","); if (groupidlist == "" && usernamelist.Text.Trim() == "") { base.RegisterStartupScript("", "<script>alert('您需要输入接收邮件用户名称或选取相关的用户组,因此邮件无法发送');</script>"); return; } int percount = 5; //每多少记录为一次等待 //发送用户列表邮件 if (usernamelist.Text.Trim() != "") { DataTable dt = Users.GetEmailListByUserNameList(usernamelist.Text); if (dt.Rows.Count <= 0) { base.RegisterStartupScript("", "<script>alert('您输入的接收邮件用户名未能查找到相关用户,因此邮件无法发送');</script>"); return; } Thread[] lThreads = new Thread[dt.Rows.Count]; int count = 0; foreach (DataRow dr in dt.Rows) { EmailMultiThread emt = new EmailMultiThread(dr["UserName"].ToString(), dr["Email"].ToString(), subject.Text, body.Text); lThreads[count] = new Thread(new ThreadStart(emt.Send)); lThreads[count].Start(); if (count >= percount) { Thread.Sleep(5000); count = 0; } count++; } } if (groupidlist == "") { base.LoadRegisterStartupScript("PAGE", "window.location.href='global_usergroupsendemail.aspx';"); return; } ClientScript.RegisterStartupScript(this.GetType(), "Page", "<script>submit_Click();</script>"); } #endregion }
/// <summary> /// 发送验证注册请求链接 /// </summary> public void SendRegisterVerifyLink() { string email = DNTRequest.GetString(config.Antispamregisteremail).Trim().ToLower(); ValidateEmail(email); if (IsErr()) { return; } InviteCodeInfo inviteCode = allowinvite ? ValidateInviteInfo() : null; if (IsErr()) { return; } VerifyRegisterInfo verifyInfo = Users.CreateVerifyRegisterInfo(email, allowinvite ? invitecode : string.Empty); if (verifyInfo != null) { string verifyLink = string.Format("{0}register.aspx?action=reg&verifycode={1}", Utils.GetRootUrl(forumpath), verifyInfo.VerifyCode); string verifyContent = string.Format(config.Verifyregisteremailtemp, verifyInfo.Email.Split('@')[0], verifyLink); EmailMultiThread emt = new EmailMultiThread(verifyInfo.Email.Split('@')[0], verifyInfo.Email, string.Format("{0} 的安全注册链接,欢迎注册!", config.Forumtitle), verifyContent); new System.Threading.Thread(new System.Threading.ThreadStart(emt.Send)).Start(); } SetUrl("index.aspx"); SetShowBackLink(false); SetMetaRefresh(2); AddMsgLine("请求已经发送,请查收邮箱"); }
private void BatchSendEmail_Click(object sender, EventArgs e) { #region 批量发送邮件 if (this.CheckCookie()) { string groupidlist = Usergroups.GetSelectString(","); if ((groupidlist == "") && (usernamelist.Text.Trim() == "")) { base.RegisterStartupScript("", "<script>alert('您需要输入接收邮件用户名称或选取相关的用户组,因此邮件无法发送');</script>"); return; } base.LoadRegisterStartupScript("PAGE", "window.location.href='global_usergroupsendemail.aspx';"); int percount = 5; //每多少记录为一次等待 //发送用户列表邮件 if (usernamelist.Text.Trim() != "") { //string strwhere = " WHERE [Email] Is Not null AND ("; //foreach (string username in usernamelist.Text.Split(',')) //{ // if (username.Trim() != "") // strwhere += " [username] like '%" + username.Trim() + "%' OR "; //} //strwhere = strwhere.Substring(0, strwhere.Length - 3) + ")"; //DataTable dt = DbHelper.ExecuteDataset("SELECT [username],[Email] From [" + BaseConfigs.GetTablePrefix + "users] " + strwhere).Tables[0]; DataTable dt = DatabaseProvider.GetInstance().MailListTable(usernamelist.Text); Thread[] lThreads = new Thread[dt.Rows.Count]; int count = 0; foreach (DataRow dr in dt.Rows) { EmailMultiThread emt = new EmailMultiThread(dr["UserName"].ToString(), dr["Email"].ToString(), subject.Text, body.Text); lThreads[count] = new Thread(new ThreadStart(emt.Send)); lThreads[count].Start(); if (count >= percount) { Thread.Sleep(5000); count = 0; } count++; //ThreadPool.QueueUserWorkItem(new WaitCallback(SendMail),string.Format("http://bbs.ent.tom.com/forum/view_thread.php?forumid=1&threadid={0}&backurl=http%3A%2F%2Fbbs.ent.tom.com%2Fforum%2Flist_thread.php%3Fforumid%3D1%26page%3D1%26sort%3D0",PageNumber.ToString())); } } //发送用户组邮件 if (groupidlist != "") { //DataTable dt = DbHelper.ExecuteDataset("SELECT [username],[Email] From [" + BaseConfigs.GetTablePrefix + "users] WHERE [Email] Is Not null AND [Email]<>'' AND [groupid] IN(" + groupidlist + ")").Tables[0]; DataTable dt = DatabaseProvider.GetInstance().GetUserEmailByGroupid(groupidlist); Thread[] lThreads = new Thread[dt.Rows.Count]; int count = 0; foreach (DataRow dr in dt.Rows) { EmailMultiThread emt = new EmailMultiThread(dr["UserName"].ToString(), dr["Email"].ToString(), subject.Text, body.Text); lThreads[count] = new Thread(new ThreadStart(emt.Send)); lThreads[count].Start(); if (count >= percount) { Thread.Sleep(5000); count = 0; } count++; //ThreadPool.QueueUserWorkItem(new WaitCallback(SendMail),string.Format("http://bbs.ent.tom.com/forum/view_thread.php?forumid=1&threadid={0}&backurl=http%3A%2F%2Fbbs.ent.tom.com%2Fforum%2Flist_thread.php%3Fforumid%3D1%26page%3D1%26sort%3D0",PageNumber.ToString())); } } base.RegisterStartupScript("PAGE", "window.location.href='global_usergroupsendemail.aspx';"); } #endregion }