首页 / 网页编程 / ASP / 简单快捷实现ASP在线发邮件功能
简单快捷实现ASP在线发邮件功能2007-05-25在编写网上应用程序时,经常碰到需要在线发送邮件的问题,邮件内容是由程序动态决定的,如果你采用的是ASP方式来编写网上应用程序,如何简单、快捷地实现这一功能呢?笔者在实践中利用ASP的com组件功能,在vb中实现了一个发邮件的小组件,在ASP中只通过轻松调用,就可以实现该功能。所有邮件处理机制都被封装在这个组件中,使用起来极为方便。下面将详细介绍该组件的基本开发原理以及在ASP中的应用。1. 利用Winsock控件与发送邮件的smtp联系和smtp的联系包括握手、发送数据以及关闭等全过程,主要程序如下:建立一个frmsendmail 的窗体,其中包含一个winsock控件,有以下几个公共变量:public mstmp as string//发送邮件的stmppublic mfrom as string//from 地址public mto as string//到达地址public msubject as string//邮件主题public mtext as string//邮件正文sock.connect mstmp, 25//和发送邮件的stmp建立联系private sub sock_connect()sflag = sfconn//连接成功后设置参数end subprivate sub sock_dataarrival(byval bytestotal as long)on error goto daerrdim s as stringsock.getdata sselect case sflagcase sfstartcase sfconnsflag = sfhelo//发出握手信息hello
send "helo " && mmynamecase sfhelosflag = sffromsend "mail from:" && getreal(mfrom)case sffromif left(s, 3) 〈〉 "250" then goto srverr//如果成功发送接收邮件地址sflag = sfrcptsend "rcpt to:" && getreal(mto)case sfrcptif left(s, 3) 〈〉 "250" then goto srverr//如果成功开始发送数据sflag = sfdatasend "data"case sfdataif left(s, 3) 〈〉 "354" then goto srverrsflag = sfsendover //数据包括4项,最后以 . 结束send "from: " && mfromsend "to: " && mtosend "subject: " && msubject && vbcrlfsend mtextsend "."case sfsendoverif left(s, 3) 〈〉 "250" then goto srverrsflag = sfstartsendok = truesend "quit"end selectexit subend sub
2. 将上述功能封装在一个类中由于ASP能使用的组件中不能存在控件,所以要通过类模块来封装上述窗体。首先在类初始化时建立一窗体:private sub class_initialize()set frm = new frmsendmailend sub把窗体的公共变量作为属性封装在类模块中。该窗体的函数接口为:public sub send()frm.sendstartend sub3. 注册该组件将上述工程编译成dll文件,通过vb注册或手工注册都可以。4. 在ASP中的应用调用方法如下:set smail=server.createobject("sendmailx.mail")smail.stmp="166.166.1.1"smail.logfile="e:logsmail.log"smail.mfrom = mfromname && " 〈" && mfromaddr && "〉"smail.mto = mtoname && " 〈" && mtoaddr && "〉"smail.msubject = msubjectsmail.mtext = mtextsmail.send其中变量可以通过赋值,也可以来自上一个request页面。