LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

利用ASP+JMAIL进行邮件群发的新思路

admin
2010年7月8日 0:27 本文热度 5453
[p]背景: [br]email地址存于mssql一用户信息表中,数量上万。 [br]公司自有服务器,集smtp,pop3,www,ftp,mssql,dns等多种服务于一身。 [br]jmail 有mailmerge对象,但是免费版不能用 [/p]
[p]要求: [br]用asp+jmail,利用公司smtp向所有用户发送email [/p]
[p]思路: [br]直接读取数据库,多次循环发送,会对本来配置不高的服务器造成很大压力。 [br]最好能对email分批发送,每批发送间隔一段时间,以此来缓解对服务器造成的压力。 [/p]
[p]实现: [br]对email分批 [br]读出记录到recordset,利用常见的分页程序,将所有记录分页,每页作为一批,有多少页就分多少批 [br]间隔延迟 [br]在每页执行完毕后用来延迟跳转 [br]减少执行时间: [br]在循环的过程中,循环添加收件人,而不要循环发送,即 [br]for i=1 to rs.pagesize [br]msg.addrecipient rs("email") [br]rs.movenext [br]next [br]msg.send ("smtp.abc.com") [br]减小邮件大小 [br]循环添加收件人,会造成一封email的收件人很多,这样一封email的就会很大。 [br]所以,在以上代码的基础上改进一下,在循环内做个判断,当收件人email数量到达 [br]20的时候就发送一次。即: [br]for i=1 to rs.pagesize [br]msg.addrecipient rs("email") [br]   if i mod 20 = 0 then         '每 20 个收信人作为一封email发送一次 [br]    msg.send ("smtp.abc.com") [br]    msg.clearrecipients         '清除已发送的收信人 [br]   end if [br]rs.movenext [br]next [br]msg.send ("smtp.abc.com")         '发送余下的 [br]页面 [br]mail.asp    包含邮件主题、正文的表单,
;一个iframe页面,