Oracle PL/SQL 实现发送电子邮件功能(UTL_MAIL)

2023-10-19 03:40

本文主要是介绍Oracle PL/SQL 实现发送电子邮件功能(UTL_MAIL),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

email

文章目录

    • 安装 UTL_MAIL
    • 发送邮件
    • 发送附件
    • 注意事项

大家好,我是只谈技术不剪发的 Tony 老师。

我们在开发 Oracle 数据库程序时,如果想要通过 PL/SQL 存储过程实现发送邮件的功能,大概可以使用以下三种方法:

  • 利用 UTL_TCP 程序包基于 TCP 协议发送邮件。这种方法比较原始,需要用户编写基础交换代码。
  • 利用 UTL_SMTP 程序包基于 SMTP 协议发送邮件。这种方法比编码 TCP 操作简单很多,支持发送电子邮件的各种操作,因此使用非常广泛。
  • 利用 UTL_MAIL 程序包发送邮件。这种方法最简单,支持常用的邮件功能,不需要了解 SMTP 协议。

今天我们要介绍的是第 3 种方法,也就是通过 UTL_MAIL 程序包在 PL/SQL 程序中实现发送邮件的功能。Oracle 10g 开始提供 UTL_MAIL 程序包。

安装 UTL_MAIL

默认情况下,系统没有安装 UTL_MAIL 程序包。因为它需要设置 SMTP_OUT_SERVER 配置参数,同时还会涉及到一些安全问题。

首先,执行以下语句安装 UTL_MAIL 程序包:

sqlplus sys/<pwd>
SQL> @$ORACLE_HOME/rdbms/admin/utlmail.sql
SQL> @$ORACLE_HOME/rdbms/admin/prvtmail.plb

然后设置 SMTP_OUT_SERVER 参数:

sqlplus sys/<pwd>
SQL> ALTER SYSTEM SET smtp_out_server='smtp.domain.com' SCOPE=SPFILE;

如果使用 Oracle 10g R1,需要重启服务,更高版本不需要。

建议在数据库服务器上设置一个邮件转发,而不是直接连接到外部的邮件服务器。邮件转发配置非常简单,设置一个引用 SMTP_OUT_SERVER 参数的 localhost 的配置。任何连接外部邮件服务器的复杂配置都隐藏在邮件转发配置中。

发送邮件

完成安装和配置之后,我们可以使用存储过程 UTL_MAIL.SEND 发送邮件:

UTL_MAIL.SEND (sender      IN    VARCHAR2 CHARACTER SET ANY_CS,recipients  IN    VARCHAR2 CHARACTER SET ANY_CS,cc          IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,bcc         IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,subject     IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,message     IN    VARCHAR2 CHARACTER SET ANY_CS,mime_type   IN    VARCHAR2 DEFAULT 'text/plain; charset=us-ascii',priority    IN    PLS_INTEGER DEFAULT 3,replyto     IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL);

这些参数的作用如下:

  • SENDER:发送者的邮件地址
  • RECIPIENTS:接收者的邮件地址,多个地址使用逗号分隔
  • CC:抄送者的邮件地址,多个地址使用逗号分隔,默认为 NULL
  • BCC:密送者的邮件地址,多个地址使用逗号分隔,默认为 NULL
  • SUBJECT:邮件主题,默认为 NULL
  • MESSAGE:邮件正文
  • MIME_TYPE:邮件的 MIME 类型,默认为 text/plain; charset=us-ascii
  • PRIORITY:邮件优先级,1 级最高,5 级最低,默认为 3
  • REPLYTO:回复邮件发送的目标地址,Oracle 11g R2 开始支持该参数

以下是一个发送邮件的简单示例:

BEGINUTL_MAIL.send(sender     => 'myname@domain.com',recipients => 'zhangsan@domain.com,lisi@domain.com',cc         => 'wangwu@domain.com',bcc        => 'myboss@domain.com',subject    => 'UTL_MAIL 测试',message    => '邮件正文',mime_type  => 'text/plain; charset=UTF-8'); -- 支持中文
END;
/

发送附件

除了发送文本邮件之外,UTL_MAIL 程序包还提供了两个支持附件的存储过程:SEND_ATTACH_RAW 以及 SEND_ATTACH_VARCHAR2 。它们分别可以用于发送 RAW 以及 VARCHAR2 格式的附件。

UTL_MAIL.SEND_ATTACH_RAW (sender           IN    VARCHAR2 CHARACTER SET ANY_CS,recipients       IN    VARCHAR2 CHARACTER SET ANY_CS,cc               IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,bcc              IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,subject          IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,message          IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,mime_type        IN    VARCHAR2 DEFAULT CHARACTER SET ANY_CSDEFAULT 'text/plain; charset=us-ascii',priority         IN    PLS_INTEGER DEFAULT 3,attachment       IN    RAW,att_inline       IN    BOOLEAN DEFAULT TRUE,att_mime_type    IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT 'text/plain; charset=us-ascii',att_filename     IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,replyto          IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL);UTL_MAIL.SEND_ATTACH_VARCHAR2 (sender            IN    VARCHAR2 CHARACTER SET ANY_CS,recipients        IN    VARCHAR2 CHARACTER SET ANY_CS,cc                IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,bcc               IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,subject           IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,message           IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL,mime_type         IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT 'text/plain; charset=us-ascii',priority          IN    PLS_INTEGER DEFAULT 3,attachment        IN    VARCHAR2 CHARACTER SET ANY_CS, ,att_inline        IN    BOOLEAN DEFAULT TRUE,att_mime_type     IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT 'text/plain; charset=us-ascii',att_filename      IN    VARCHAR2CHARACTER SET ANY_CS DEFAULT NULL,replyto           IN    VARCHAR2 CHARACTER SET ANY_CS DEFAULT NULL);

这两个存储过程比 UTL_MAIL.SEND 支持以下额外的参数:

  • ATTACHMENT:附件内容,数据类型为 RAW 或者 VARCHAR2
  • ATT_INLINE:指定附件是否在邮件正文中显式,默认为 TRUE
  • ATT_MIME_TYPE:附件的 MIME 类型,默认为 ‘application/octet’ 或者 ‘text/plain; charset=us-ascii’
  • ATT_FILENAME:附件的文件名,默认为 NULL

以下是一个发送文本附件的示例:

BEGINUTL_MAIL.send(sender     => 'myname@domain.com',recipients => 'zhangsan@domain.com,lisi@domain.com',cc         => 'wangwu@domain.com',bcc        => 'myboss@domain.com',subject    => 'UTL_MAIL 测试',message    => '邮件正文',mime_type  => 'text/plain; charset=UTF-8', -- 支持中文attachment => '附件内容',att_mime_type => 'text/plain; charset=UTF-8', -- 支持中文att_filename => '附件.txt');
END;
/

注意事项

UTL_MAIL 程序包使用调用者权限,也就是说使用该程序的用户需要拥有访问外部邮件服务器的权限。

如果遇到以下错误,表示缺少相应的权限。

ORA-24247: network access denied by access control list (ACL)

此时我们可以通过以下语句授予指定用户(例如 scott)访问外部服务器上的 SMPT 服务权限:

BEGIN;DBMS_NETWORK_ACL_ADMIN.APPEND_HOST_ACE(host => 'www.domain.comm',ace  =>  xs$ace_type(privilege_list => xs$name_list('smtp'),principal_name => 'scott',principal_type => xs_acl.ptype_db)); 
END;
/

详细内容可以参考官方文档。

这篇关于Oracle PL/SQL 实现发送电子邮件功能(UTL_MAIL)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/237055

相关文章

使用FileChannel实现文件的复制和移动方式

《使用FileChannel实现文件的复制和移动方式》:本文主要介绍使用FileChannel实现文件的复制和移动方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录使用 FileChannel 实现文件复制代码解释使用 FileChannel 实现文件移动代码解释

Spring实现Bean的初始化和销毁的方式

《Spring实现Bean的初始化和销毁的方式》:本文主要介绍Spring实现Bean的初始化和销毁的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Bean的初始化二、Bean的销毁总结在前面的章节当中介绍完毕了ApplicationContext,也就

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

Django之定时任务django-crontab的实现

《Django之定时任务django-crontab的实现》Django可以使用第三方库如django-crontab来实现定时任务的调度,本文主要介绍了Django之定时任务django-cront... 目录crontab安装django-crontab注册应用定时时间格式定时时间示例设置定时任务@符号

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

Python中edge-tts实现便捷语音合成

《Python中edge-tts实现便捷语音合成》edge-tts是一个功能强大的Python库,支持多种语言和声音选项,本文主要介绍了Python中edge-tts实现便捷语音合成,具有一定的参考价... 目录安装与环境设置文本转语音查找音色更改语音参数生成音频与字幕总结edge-tts 是一个功能强大的

Java实现按字节长度截取字符串

《Java实现按字节长度截取字符串》在Java中,由于字符串可能包含多字节字符,直接按字节长度截取可能会导致乱码或截取不准确的问题,下面我们就来看看几种按字节长度截取字符串的方法吧... 目录方法一:使用String的getBytes方法方法二:指定字符编码处理方法三:更精确的字符编码处理使用示例注意事项方

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

Android 实现一个隐私弹窗功能

《Android实现一个隐私弹窗功能》:本文主要介绍Android实现一个隐私弹窗功能,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 效果图如下:1. 设置同意、退出、点击用户协议、点击隐私协议的函数参数2. 《用户协议》、《隐私政策》设置成可点击的,且颜色要区分出来res/l