明凯博客

关注网站技术,一个特立独行的程序员

ASP定时邮件发送功能详解

现在的这个项目需要用asp做定时邮件发送,好多人都说asp没有这样的功能。

其实我在以前的一篇文章已经做过详细的解释了,不过那个是定时任务,基本思路是一样的。

ASP如何执行定时任务工作

这里我们使用JMail组件的方式来做,邮件的内容为单个网页,可以自由定制。

下面我们看看定时邮件发送的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
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
dim username,useremail
dim pass,content
dim mailname,mailpass,mailform,mailsmtp
mailname="xxx" 'smtp邮箱的账号
mailpass="xxx" 'smtp邮箱的密码
mailform="xxx" 'smtp邮箱的署名
mailsmtp="xxx" 'smtp邮箱的smtp
MailAddress=mailsmtp ': 发件服务器的地址,如smtp.163.com
Sender=title'      : 发件人姓名
Content=content'     : 邮件内容
FromEmail=mailname'   : 发件人邮件地址
Fromer=title      ': 发件人姓名
UserName=mailform'    : 发件邮件帐号
PassWord=mailpass'    : 发件邮件密码
 
 
'需要指定的内容
content=getHTTPPage("http://www.aimks.com/")
Subject="标题"     ': 邮件标题
Tomail="xxx"     ': 收件人邮件地址
call SendAction(subject,mailaddress,Tomail,sender,content,fromEmail,Fromer,UserName,PassWord)

将这个文件设置为XXX.VBS以后放到数据库定时执行就可以了。

如果有什么不懂的可以直接问MK。

, ,

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注