CREATE OR REPLACE PROCEDURE PRC_sendmail(p_receiver VARCHAR2, -- 邮件接收人                                          p_subject  VARCHAR2, -- 邮件标题                                          p_message  VARCHAR2 -- 邮件正文                                          ) IS   --下面四个变量请根据实际邮件服务器进行赋值   v_smtphost VARCHAR2(30) := 'smtp.qq.com'; --SMTP服务器地址(hotmail为smtp.live.com,测试未通过)   v_smtpport number(5) := 25; --smtp服务端口   v_user     VARCHAR2(30) := '45@qq.com'; --登录SMTP服务器的用户名   v_pass     VARCHAR2(20) := 'xiyuan'; --登录SMTP服务器的密码   v_sender   VARCHAR2(50) := '45@qq.com'; --发送者邮箱,一般与 ps_user 对应   v_conn     UTL_SMTP.connection; --到邮件服务器的连接   v_msg      varchar2(4000); --邮件内容

BEGIN

v_conn := UTL_SMTP.open_connection(v_smtphost, v_smtpport);   --是用 ehlo() 而不是 helo() 函数   --否则会报:ORA-29279: SMTP 永久性错误: 503 5.5.2 Send hello first.   UTL_SMTP.ehlo(v_conn, v_smtphost);

-- smtp服务器登录校验   UTL_SMTP.command(v_conn, 'AUTH LOGIN');   UTL_SMTP.command(v_conn,                    UTL_RAW.cast_to_varchar2(UTL_ENCODE.base64_encode(UTL_RAW.cast_to_raw(v_user))));   UTL_SMTP.command(v_conn,                    UTL_RAW.cast_to_varchar2(UTL_ENCODE.base64_encode(UTL_RAW.cast_to_raw(v_pass))));

--设置发件人及收件人   UTL_SMTP.mail(v_conn, '<' || v_sender || '>');   UTL_SMTP.rcpt(v_conn, '<' || p_receiver || '>');

-- 创建要发送的邮件内容 注意报头信息和邮件正文之间要空一行   v_msg := 'Date:' || TO_CHAR(SYSDATE, 'yyyy mm dd hh24:mi:ss') ||            UTL_TCP.CRLF || 'From: ' || v_sender || '' || UTL_TCP.CRLF ||            'To: ' || p_receiver || '' || UTL_TCP.CRLF || 'Subject: ' ||            p_subject || UTL_TCP.CRLF || UTL_TCP.CRLF -- 这前面是报头信息            || p_message; -- 这个是邮件正文

--打开流   UTL_SMTP.open_data(v_conn);   --标题和内容都都可用中文                                     UTL_SMTP.write_raw_data(v_conn, UTL_RAW.cast_to_raw(v_msg));   --关闭流   UTL_SMTP.close_data(v_conn);   --关闭连接                                   UTL_SMTP.quit(v_conn);

EXCEPTION   WHEN OTHERS THEN     DBMS_OUTPUT.put_line(DBMS_UTILITY.format_error_stack);     DBMS_OUTPUT.put_line(DBMS_UTILITY.format_call_stack);     UTL_SMTP.quit(v_conn);   END PRC_sendmail;

执行脚本:

SQL > exec PRC_sendmail(p_receiver => '751365252@qq.com', p_subject => 't张ttt', p_message => 'yy在yy');

oracle 邮件发送的更多相关文章

  1. 【Java EE 学习 21 下】【使用java实现邮件发送、邮件验证】

    一.邮件发送 1.邮件发送使用SMTP协议或者IMAP协议,这里使用SMTP协议演示. SMTP协议使用的端口号:25 rfc821详细记载了该协议的相关信息 (1)使用telnet发送邮件(使用12 ...

  2. java实现smtp邮件发送

    一.准备工作 首先你需要已一个发送邮箱,一般的邮箱都有SMTP.POP3服务,比如QQ邮箱,登陆QQ邮箱开启SMTP服务,开启是服务器会提示你设置独立密码,这个密码是跟邮箱正常登陆的密码不同的,这个是 ...

  3. PL/SQL 下邮件发送程序

    对DBA而言,尽管在os级别下发送邮件是轻而易举的事情,然而很多时候我们也需要在PL/SQL中来发送邮件,比如监控job的执行状况等.本文根据网友(源作者未考证)的代码将其改装并封装到了package ...

  4. JavaMail API 1.4.7邮件发送

    下载oracle javaMail API: http://www.oracle.com/technetwork/java/javasebusiness/downloads/java-archive- ...

  5. JavaMail邮件发送不成功的那些坑人情况及分析说明

    [我的Segmentfault原文]https://segmentfault.com/a/1190000008030346 前言   JavaMail的使用本身并不难,网上有不少案例,简单易懂,而且有 ...

  6. testng + reportng 测试结果邮件发送

    https://blog.csdn.net/qq744746842/article/details/51497506 其实大多数的时候我们的测试报告的发送可能都是结合Jenkins发送的,所以这方面更 ...

  7. Oracle邮件推送函数

    CREATE OR REPLACE PROCEDURE PROCSENDEMAIL ( P_TXT VARCHAR2, P_SUB VARCHAR2, P_SENDOR VARCHAR2, P_REC ...

  8. Java 基于JavaMail的邮件发送

    http://blog.csdn.net/xietansheng/article/details/51673073 http://blog.csdn.net/xietansheng/article/d ...

  9. Java Mail邮件发送的简单实现

    1.什么是java mail JAVA MAIL是利用现有的邮件账户发送邮件的工具,通过JAVA Mail的操控,让程序自动的使用设置的邮箱发送邮件. 这一机制被广泛的用在注册激活和垃圾邮件的发送等方 ...

随机推荐

  1. php查询文件扩展名

    //查询文件扩展名 function extension($str){ $str = implode("",explode("\\",$str)); $str ...

  2. 最近这两天看了关于H5游戏开发的一个教程,实践很短暂,看了很多理论的东西,现在呢也只是想回忆回忆关于EUI的部分知识吧

    首先我了解了什么是Egret: Egret中文就是白鹭的意思,Egret是一套H5游戏开发的软件.(纯粹属于个人理解) 其次我对以下几款软件的相关知识做了些了解: Egret Engine(引擎),E ...

  3. JS中new到底发生了什么

    outline prototype 与 __proto__ function 与 object new 到底发生了什么 prototype 与 __proto__ 首先说下在JS中比较容易让人困惑的  ...

  4. code标签和pre标签

    code标签: 1.code标签的定义: <code>标签, 用于表示计算机源代码或者其他机器可以阅读的文本内容.软件代码的编写者习惯了编写代码时的代码格式,那么这个<code> ...

  5. DMA控制器

    DMA控制器依赖于平台硬件,这里只对i386的8237 DMA控制器做简单的说明,它有两个控制器,8个通道,具体说明如下: 控制器1: 通道0-3,字节操作, 端口为 00-1F 控制器2: 通道 4 ...

  6. const成员变量初始化总结

    const可以用来声明常量也就是说他的值不能被修改: const成员必须在定义的时候同时初始化,不能进行赋值 如 const int a:a的值不能修改,不能给它赋值,如何才能让它一开始就拥有一个值? ...

  7. springMVC 返回json 忽略类中属性的注解

    该注解使用在 类名,接口头上 @JsonIgnoreProperties(value={"comid"}) //希望动态过滤掉的属性 该注解使用在get方法头上 @JsonIgno ...

  8. Myeclipse添加外部Tomcat出现启动故障的问题解决

    故障: 1.java.lang.IllegalStateException: No output folder 分析:work文件夹无写权限 解决:找到tomcat的安装文件夹,右键点击work文件夹 ...

  9. UIScrollView在AutoLayout下的滚动问题

    使用Storyboard编写UI,设置支持AutoLayout. 在其中的一个场景上,添加一个UIScrollView,在对应的代码里增加 - (void)viewDidLoad { [super v ...

  10. Date 对象中的 getYear 和 getFullYear方法

    生成一个新的日期对象 : var someDate=new Date(); 获取日期月份中的天数: var date=someDate.getDate(); 获取 4 位数的年份: var year= ...