現在的這個項目需要用asp做定時郵件發送,好多人都說asp沒有這樣的功能。
其實我在以前的一篇文章已經做過詳細的解釋了,不過那個是定時任務,基本思路是一樣的。
參考:ASP中實現執行定時任務的方法
這裡我們使用JMail組件的方式來做,郵件的內容為單個網頁,可以自由定制。
下面我們看看定時郵件發送的代碼:
複製代碼代碼如下:
Function getHTTPPage(url)
dim objXML
set objXML=createobject("MSXML2.SERVERXMLHTTP.3.0") '調用XMLHTTP組件,測試空間是否支持XMLHTTP
objXML.open "GET",url,false 'false表示以同步的方式獲取網頁代碼,了解什麼是同步?什麼是異步?
objXML.send() '發送
getHTTPPage=bBytesToBstr(objXML.responseBody)'返回信息,同時用函數定義編碼
set objXML=nothing'關閉
End Function
Function bBytesToBstr(body)
dim objstream
set objstream = CreateObject("adodb.stream") '//調用adodb.stream組件
objstream.Type = 1
objstream.Mode =3
objstream.Open
objstream.Write body
objstream.Position = 0
objstream.Type = 2
objstream.Charset = "GB2312"
'轉換原來默認的UTF-8編碼轉換成GB2312編碼,否則直接用XMLHTTP調用有中文字符的網頁得到的將是亂碼
bBytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
end Function
Sub SendAction(subject,mailaddress,Tomail,sender,content,fromEmail,Fromer,UserName,PassWord)
Set oJmail=CreateObject("Jmail.Message")
oJmail.Logging=false
oJmail.Silent=True
oJMail.Priority = 3
oJmail.FromName=Fromer
oJmail.From= FromEmail
oJmail.CharSet="gb2312"
oJmail.MailServerUserName = UserName
oJmail.MailServerPassWord = PassWord
oJmail.ContentTransferEncoding = "base64"
oJMail.HTMLBody = content '郵件內容
oJMail.Body =content'"我們的郵件採用了HTML格式,但是您的郵件查看軟件可能不支持"
oJmail.AddRecipient Tomail '收件人地址
oJmail.Subject = subject '標題
oJmail.Send(mailaddress)
End Sub
dim Subject,MailAddress,ToEmail,Sender,FromEmail,Fromer,PassWord,oJmail,usernames,tomail