--代发邮件存储过程源码如下:

CREATE OR REPLACE PROCEDURE send_mail(p_recipient VARCHAR2, -- 邮件接收人
                                      p_subject   VARCHAR2, -- 邮件标题
                                      p_message   VARCHAR2 -- 邮件正文
                                      ) IS

--下面四个变量请根据实际邮件服务器进行赋值
  v_mailhost VARCHAR2(30) := 'smtp.szlongtu.com'; --SMTP服务器地址
  v_user     VARCHAR2(30) := 'wcwen@qq.com'; --登录SMTP服务器的用户名
  v_pass     VARCHAR2(20) := 'XXXXXX'; --登录SMTP服务器的密码
  v_sender   VARCHAR2(50) := 'wcwen@qq.com'; --发送者邮箱,一般与 ps_user 对应

v_conn UTL_SMTP. connection; --到邮件服务器的连接
  v_msg  varchar2(4000); --邮件内容

BEGIN

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

UTL_SMTP.command(v_conn, 'AUTH LOGIN'); -- smtp服务器登录校验
  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))));
  --  dbms_output.put_line('...........................');

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

UTL_SMTP.rcpt(v_conn, '<' || p_recipient || '>'); --设置收件人

-- 创建要发送的邮件内容 注意报头信息和邮件正文之间要空一行
  v_msg := 'Date:' || TO_CHAR(SYSDATE, 'dd mon yy hh24:mi:ss') ||
           UTL_TCP.CRLF || 'From: ' || '<' || v_sender || '>' ||
           UTL_TCP.CRLF || 'To: ' || '<' || p_recipient || '>' ||
           UTL_TCP.CRLF || 'Subject: ' || p_subject || UTL_TCP.CRLF ||
           UTL_TCP.CRLF -- 这前面是报头信息
           || p_message; -- 这个是邮件正文
  dbms_output.put_line(v_msg);
  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);
 
END send_mail;

--配置acl

select * from dba_network_acls;

>创建acl

BEGIN
  DBMS_NETWORK_ACL_ADMIN.create_acl(acl         => 'acl_sendmail_for_icme.xml',
                                    description => 'send mail of the ACL functionality',
                                    principal   => 'SCOTT',
                                    is_grant    => TRUE,
                                    privilege   => 'connect',
                                    start_date  => null,
                                    end_date    => NULL);

COMMIT;
END;
/

>SELECT any_path FROM resource_view WHERE any_path like '/sys/acls/%.xml';

>添加主机或域名

BEGIN
  DBMS_NETWORK_ACL_ADMIN.assign_acl(acl        => 'acl_sendmail_for_icme.xml',
                                    host       => 'smtp.szlongtu.com',
                                    lower_port => 25,
                                    upper_port => null);
END;
/

DECLARE
  v_mailsever_host VARCHAR2(30) := 'smtp.szlongtu.com';
  v_mailsever_port PLS_INTEGER := 25;
  l_mail_conn      UTL_SMTP.CONNECTION;
BEGIN
  l_mail_conn := UTL_SMTP.OPEN_CONNECTION(v_mailsever_host,
                                          v_mailsever_port);
END;
/

select DBMS_NETWORK_ACL_ADMIN.CHECK_PRIVILEGE('acl_sendmail_for_icme.xml','SCOTT','connect') from dual;

grant execute on send_mail to scott;

select DBMS_NETWORK_ACL_ADMIN.CHECK_PRIVILEGE('acl_sendmail_for_icme.xml','SYS','connect') from dual;

>授权用户

BEGIN
  dbms_network_acl_admin.add_privilege(acl        => 'acl_sendmail_for_icme.xml',
                                       principal  => 'SYS',
                                       is_grant   => TRUE,
                                       privilege  => 'connect',
                                       start_date => SYSTIMESTAMP,
                                       end_date   => NULL);
  COMMIT;
END;
/

SELECT acl,
       principal,
       privilege,
       is_grant,
       TO_CHAR(start_date, 'DD-MON-YYYY') AS start_date,
       TO_CHAR(end_date, 'DD-MON-YYYY') AS end_date
  FROM dba_network_acl_privileges;

--清空acl信息

BEGIN
  DBMS_NETWORK_ACL_ADMIN.drop_acl(acl => 'acl_sendmail_for_icme.xml');
end;

最新文章

  1. AIX系统的日常监控维护
  2. Java Socket编程
  3. 测试Swift语言代码高亮-使用highlight.js
  4. Metasploit辅助模块
  5. DIY_hlstudio_WIN7PE【69M】网络版【89M】
  6. C#基础精华08(反射,程序集)
  7. CSS之生成全屏背景图片
  8. iOS开发核心语言Objective C —— 所有知识点总结
  9. Linux(Debian)上安装Redis教程
  10. POJ 1472 Coins (多重背包+滚动数组)
  11. 2.如何实现使用VBS脚本程序对直播间自动评论
  12. netconf选用秘钥登录
  13. POJ - 2251 bfs [kuangbin带你飞]专题一
  14. Java基础---Java---面试题---交通灯管理系统(面向对象、枚举)
  15. DB 查询分析器 6.03 在Windows 8 上安装与运行演示
  16. CCF CSP 201609-2 火车购票
  17. 加快Gradle的构建过程
  18. Property referenced in indexed property path is neither an array nor a List nor a Map
  19. mysql的部署
  20. 4-(基础入门篇)学会刷Wi-Fi模块固件(刷AT指令固件)

热门文章

  1. e649. 处理焦点改变事件
  2. linux -- 常用的20个命令
  3. js上传本地图片遇到的问题
  4. 上传文件到 Sharepoint 的文档库中和下载 Sharepoint 的文档库的文件到客户端
  5. 建造者模式(build pattern)-------创造型模式
  6. MVC+LINQToSQL的Repository模式之(一)数据工厂 DataContext绑定线程
  7. C#------各种数据库连接字符串编写
  8. org.springframework.beans.factory.xml.XmlBeanDefinitionStoreException: Line 12 in XML document from
  9. Messages: No result defined for action cn.itcast.oa.test.TestAction and result SUCCESS
  10. Linux-Oracle