从Oracle 8i开始,这个数据库就已经能够通过UTL_SMTP工具包发送电子邮件了。它提供的PL/SQL工具包实现了RFC所定义的简单邮件传输协议(Simple Mail Transfer Protocol,SMTP)。
Oracle 10g加入了一个新的工具包——UTL_MAIL,它免除了先前的工具包所需要的额外工作。它是对现在仍在使用的UTL_SMTP外加的一个层。
为了体会一下UTL_MAIL所带来的便利,现在就让我们先看一下以前的处理方法。UTL_SMTP里的函数会模仿电子邮件会话的步骤。首先,它首先用UTL_SMTP.OPEN_CONNECTION函数连接到电子邮件服务器的指定端口上。一旦成功建立连接,多个函数会被按顺序调用来与邮件服务器进行通信。UTL_SMTP.HELO过程会通过向服务器发送HELO(“hello”)消息建立一个邮件会话。然后UTL_STMP.MAIL会识别发送者的电子邮箱,UTL_SMTP.RCPT会识别接受者,而UTL_SMTP.DATA会发送消息文本。最后进程由UTL_SMTP.QUIT来结束。
通过使用UTL_MAIL,这多个函数被合并成了一个叫做UTL_MAIL.SEND的存储过程。它的格式是:
UTL_MAIL.SEND (sender, recipientlist, cc, bcc, subject,
Message, mime_type, priority)
Recipientlist、cc和bcc参数都是用逗号隔开的接受、抄送和密件抄送人员列表。发送者、主题、消息和mime_type参数都是单个项目字段。上述所有内容都被定义为VARCHAR2。最后一个参数priority是一个用来定义消息优先级别的PLS_INTEGER。
这个工具包还带有两个处理附件的过程。SEND_ATTACH_RAW和SEND_ATTACH_VARCHAR2过程与SEND类似,但是带有一个额外的参数,用来发送附件的RAW或者VARCHAR2类型。
注:在默认情况下,处于安全的考虑UTL_MAIL没有被配置。你必须以SYS的身份连接进行安装,然后执行$ORACLE_HOME/rdbms/admin目录下的utlmail.sql脚本。此外,你还必须配置一个初始化参数——SMTP_OUT_SERVER,指向一个出站SMTP服务器(和UTL_STMP不同,它没有在函数参数里指定,所以必须预定义)。
自由广告区 |
分类导航 |
邮件新闻资讯: IT业界 | 邮件服务器 | 邮件趣闻 | 移动电邮 电子邮箱 | 反垃圾邮件|邮件客户端|网络安全 行业数据 | 邮件人物 | 网站公告 | 行业法规 网络技术: 邮件原理 | 网络协议 | 网络管理 | 传输介质 线路接入 | 路由接口 | 邮件存储 | 华为3Com CISCO技术 | 网络与服务器硬件 操作系统: Windows 9X | Linux&Uinx | Windows NT Windows Vista | FreeBSD | 其它操作系统 邮件服务器: 程序与开发 | Exchange | Qmail | Postfix Sendmail | MDaemon | Domino | Foxmail KerioMail | JavaMail | Winwebmail |James Merak&VisNetic | CMailServer | WinMail 金笛邮件系统 | 其它 | 反垃圾邮件: 综述| 客户端反垃圾邮件|服务器端反垃圾邮件 邮件客户端软件: Outlook | Foxmail | DreamMail| KooMail The bat | 雷鸟 | Eudora |Becky! |Pegasus IncrediMail |其它 电子邮箱: 个人邮箱 | 企业邮箱 |Gmail 移动电子邮件:服务器 | 客户端 | 技术前沿 邮件网络安全: 软件漏洞 | 安全知识 | 病毒公告 |防火墙 攻防技术 | 病毒查杀| ISA | 数字签名 邮件营销: Email营销 | 网络营销 | 营销技巧 |营销案例 邮件人才:招聘 | 职场 | 培训 | 指南 | 职场 解决方案: 邮件系统|反垃圾邮件 |安全 |移动电邮 |招标 产品评测: 邮件系统 |反垃圾邮件 |邮箱 |安全 |客户端 |