Asp.net实现的邮件发送引擎[网络技术]
本文“Asp.net实现的邮件发送引擎[网络技术]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
用asp.net发送Email已经不是一件新颖的事情了.可以采取很多种办法来发送,比方SmtpMail办法,Socket办法,通过第三方组件Jmail等方法都可以.但是本文谈论的不是发送邮件采取的技术,而是通过公司的一个项目实践说说邮件引擎的架构,有不足和改良之处,欢送同行批判指正.
我们从前发送邮件的时刻采取的办法就是,在页面里面触发举行发送,比方注册了会员,点了提交按钮之后,将会员数据插入到数据库,然后举行发送.这种办法固然简单便利,但是有一个弱点,假如邮件发送失利,就不能重发了.因此,在我们项目中采取的办法是,将需求发送的邮件统一插入到一个邮件行列,然后由引擎来处理这个行列.具体的做法是,数据库计划:
Win_EmailQueue(邮件行列表)
QueueId int 自动编号,主键Id
ToEmail nvarchar(100) 收件人
Title nvarchar(100) 邮件标题
Content ntext 邮件内容
AddDate datetime 增添时间
TryTimes int 错误重试次数
LastSendTime datetime 最后一次发送的时间
Status int 状况:0 未发送 1 已经发送
需求发送邮件的时刻,如注册会员成功后,将邮件的内容插入到表中.
邮件引擎可以用一个系统服务来完成,安装在Web服务器同一台服务器上面,也可以按照负载实际情形安装在别的一台服务器上面,减轻Web服务器负担.邮件引擎的任务是隔断一个时间(比方5秒),查询邮件行列,按照时间次序发送邮件,为了降低引擎的负担,可以设置每次发送15封,当然这个数字要按照实际情形来配置.
///
/// 发送Email行列,
///
public static void SendEmailQueue()
{
//取最新的15条未成功的举行发送.
string sql = "select top 15 * from Win_EmailQueue where Status=0 and ToEmail<>'' order by AddDate desc";
DataTable dt = DbHelperSQL.Query(sql).Tables[0];
for (int i = 0; i < dt.Rows.Count; i++)
{
string title = dt.Rows[i]["Title"].ToString();
string content = dt.Rows[i]["Content"].ToString();
string to = dt.Rows[i]["ToEmail"].ToString();
string CreateTime = dt.Rows[i]["AddDate"].ToString();
string QueueID = dt.Rows[i]["QueueID"].ToString();
bool flag = EmailUtil.Send(title, to, content);
if (flag)
以上是“Asp.net实现的邮件发送引擎[网络技术]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |