利用ASP+JMAIL進行郵件群發的新思路
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
[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 包含郵件主題、正文的表單, |
關鍵字查詢
相關文章
正在查詢... |