热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用UTL_SMTP发送邮件。

以下示例代码使用预定义的程序包UTL_SMTP发送邮件。该软件包首先在版本8.1.7中可用。createorreplaceproceduresendmail(sendervarch

以下示例代码使用预定义的程序包UTL_SMTP发送邮件。

该软件包首先在版本8.1.7中可用。


create or replace procedure sendmail(sender varchar2,recipient varchar2,subject varchar2, text 
 
varchar2)

IS

mailhost    VARCHAR2(64) := '192.168.1.32';

--The name of the SMTP server host

port constant number(2):=25;

--The port number on which SMTP server is listening (usually 25).

timeout number :=180;

--The time in seconds that the UTL_SMTP package waits before giving up in a read or write 
 
operation in this connection. 

--In read operations, this package gives up if no data is available for reading immediately. 

--In write operations, this package gives up if the output buffer is full and no data is to be 
 
sent into the network without being blocked. 

--Zero (0) indicates not to wait at all. 

--NULL indicates to wait forever.

mail_conn  utl_smtp.connection;

BEGIN

--dbms_output.put_line(UTL_SMTP.VRFY (mail_conn,recipient));

mail_conn := utl_smtp.open_connection(mailhost, port,timeout);

--Helo performs initial handshaking with SMTP server after connecting

utl_smtp.helo(mail_conn, mailhost);

--Mail Initiates a mail transaction with the server

utl_smtp.mail(mail_conn, sender);

--Specifies the recipient of an e-mail message

utl_smtp.rcpt(mail_conn, recipient);

-- open_data(), write_data(), and close_data() into a single call to data().

--Sends the DATA command

utl_smtp.open_data(mail_conn);

utl_smtp.write_data(mail_conn,'From'||':'|| Sender || UTL_TCP.CRLF);

utl_smtp.write_data(mail_conn,'To'||':'|| recipient || UTL_TCP.CRLF);

utl_smtp.write_data(mail_conn,'Subject' ||':'|| subject || UTL_TCP.CRLF);

--Writes a portion of the e-mail message

utl_smtp.write_data(mail_conn, text);

--Closes the data session

utl_smtp.close_data(mail_conn);

utl_smtp.quit(mail_conn);

--dbms_output.put_line('Your message has been sent...!');

EXCEPTION

WHEN UTL_SMTP.PERMANENT_ERROR THEN
BEGINutl_smtp.quit(mail_conn);END;
RAISE_APPLICATION_ERROR(-20101,'This id has Permanent Error');

WHEN UTL_SMTP.TRANSIENT_ERROR THEN
BEGINutl_smtp.quit(mail_conn);END;
RAISE_APPLICATION_ERROR(-20102,'SMTP transient error:');

WHEN UTL_SMTP.INVALID_OPERATION THEN
BEGINutl_smtp.quit(mail_conn);END;
RAISE_APPLICATION_ERROR(-20103,'Invalid Operation in Mail using UTL_SMTP.');

WHEN OTHERS THEN

RAISE_APPLICATION_ERROR(-20104,'Some other Error ...!');

end;

/
  
要执行上述过程,请尝试以下代码。


exec sendmail('sender@sender.com','recipient@recipient.com','Hi','Test Mail');
 

From: https://bytes.com/topic/oracle/insights/771381-sending-mail-using-utl_smtp



推荐阅读
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • OpenMap教程4 – 图层概述
    本文介绍了OpenMap教程4中关于地图图层的内容,包括将ShapeLayer添加到MapBean中的方法,OpenMap支持的图层类型以及使用BufferedLayer创建图像的MapBean。此外,还介绍了Layer背景标志的作用和OMGraphicHandlerLayer的基础层类。 ... [详细]
  • Ihavebeenworkingwithbufferingafileonmylocaldrivetoparseandobtaincertaindata.Forte ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 本文介绍了pack布局管理器在Perl/Tk中的使用方法及注意事项。通过调用pack()方法,可以控制部件在显示窗口中的位置和大小。同时,本文还提到了在使用pack布局管理器时,应注意将部件分组以便在水平和垂直方向上进行堆放。此外,还介绍了使用Frame部件或Toplevel部件来组织部件在窗口内的方法。最后,本文强调了在使用pack布局管理器时,应避免在中间切换到grid布局管理器,以免造成混乱。 ... [详细]
  • Iamtryingtocreateanarrayofstructinstanceslikethis:我试图创建一个这样的struct实例数组:letinstallers: ... [详细]
  • 使用C++编写程序实现增加或删除桌面的右键列表项
    本文介绍了使用C++编写程序实现增加或删除桌面的右键列表项的方法。首先通过操作注册表来实现增加或删除右键列表项的目的,然后使用管理注册表的函数来编写程序。文章详细介绍了使用的五种函数:RegCreateKey、RegSetValueEx、RegOpenKeyEx、RegDeleteKey和RegCloseKey,并给出了增加一项的函数写法。通过本文的方法,可以方便地自定义桌面的右键列表项。 ... [详细]
  • 本文介绍了使用C++Builder实现获取USB优盘序列号的方法,包括相关的代码和说明。通过该方法,可以获取指定盘符的USB优盘序列号,并将其存放在缓冲中。该方法可以在Windows系统中有效地获取USB优盘序列号,并且适用于C++Builder开发环境。 ... [详细]
  • 图片添加二维码水印教程
    本博客介绍一下用jdkawt实现图片加文字水印和图片水印的方法一、图片文字水印原来图片加上文字水印后图片二、图片加图片水印原来图片:水印图片:添加水印后的图片: ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
author-avatar
无正道
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有