从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不同,它没有在函数参数里指定,所以必须预定义)。
新闻热点
疑难解答