Oracle邮件发送(内容中带有收件人独有信息)
Oracle邮件发送(内容中带有收件人独有信息)
Oracle邮件发送(内容中带有收件人独有信息)
Oracle发送邮件最简单的应该就是用smtp,具体使用和参数讲解我这儿没有
简单来说,发送邮件的思路就是
确认收件人的信息(邮箱账号密码)
确认服务器的信息(SMTP的服务器ip,地址等)
确认邮件头信息(发件人,收件人,主题)
确认邮件内容(内容为HTML格式,可以用编译器(比如vscode)先设计好,然后再往里面塞)
直接拿一个例子来说明(编译器为PL/SQL),需求是从用户表中找到创建时间在两天之内的用户,邮件欢迎并通知相关内容,内容中要带有用户的姓名以及一些独有信息
存储包的头
create or replace package send_email_pak is
--执行
procedure send_email_main;
--发送邮件
procedure send_mail(p_userid varchar2, p_email varchar2);
end send_email_pak;
存储包的体,打了一堆注释
--------------------以下为体---------------------
create or replace package body send_email_pak is
type g_email_tbl is table of varchar2(100) index by binary_integer;
/*==================================================
获取用户并执行发送邮件,对每个人都发送一封
==================================================*/
procedure send_email_main is
--获取最近两天的用户,已经发过的就不用发了
cursor aaa is
select u.userid, u.email
from user_table_name u--取出用户表内容
where u.createtime > to_char(sysdate - 2, 'yyyy-mm-dd')--创建时间在两天之内
and u.email is not null--只要有邮箱的
and not exists (select 1 from send_email_log s where s.userid = u.userid);--发过的就不发了
begin
--打开游标取内容
for main in aaa loop
--执行发送邮件的方法
--为什么不直接批量发送,是因为在邮件内容中使用了每个收件人的名字作为其中的内容,所以就直接一对一多次执行实现了
send_mail(main.userid, main.email);
--记录发送日志
insert into send_email_log(userid,logtime)(select main.userid,sysdate from dual);
end loop;
end send_email_main;
/*==================================================
初始化邮箱
==================================================*/
procedure cshyx(p_email varchar2,p_conn out utl_smtp.connection) is
begin
p_conn := utl_smtp.open_connection(smtp服务器主机的ip,smtp服务器正在侦听的端口号);
utl_smtp.ehlo(p_conn, smtp服务器地址);
utl_smtp.command(p_conn, 'auth login');--smtp服务器登录校验
utl_smtp.command(p_conn,utl_raw.cast_to_varchar2(utl_encode.base64_encode(utl_raw.cast_to_raw(发件人邮箱账号))));
utl_smtp.command(p_conn,utl_raw.cast_to_varchar2(utl_encode.base64_encode(utl_raw.cast_to_raw(发件人邮箱密码))));
utl_smtp.mail(p_conn, 发件人邮箱账号);
utl_smtp.rcpt(p_conn, 收件人邮箱账号);
utl_smtp.open_data(p_conn);
utl_smtp.write_data(p_conn, 'from: '||p_smtpemail|| utl_tcp.crlf); --发件人地址
utl_smtp.write_data(p_conn, 'to:'||p_email||''|| utl_tcp.crlf); --收件人地址
utl_smtp.write_raw_data(p_conn, utl_raw.cast_to_raw(convert('subject:' || '主题' ||utl_tcp.crlf,'zhs16gbk')));--主题
exception
when utl_smtp.transient_error or utl_smtp.permanent_error then
utl_smtp.quit(p_conn);
end cshyx;
/*==================================================
发送短信的主体
==================================================*/
procedure send_mail(p_userid varchar2, p_email varchar2) is
v_body long;
v_start long;
conn utl_smtp.connection;
begin
--开始拼接html内容
v_start := '<html><body>';
--初始化邮箱
cshyx(p_email,conn);
--简体中文
utl_smtp.write_raw_data(conn,utl_raw.cast_to_raw(convert('content-type:text/html;charset=gb2312' ||utl_tcp.crlf, 'zhs16gbk')));
utl_smtp.write_data(conn, utl_tcp.crlf);
--拼出来的html内容主体
v_body := v_start || '<br><tr><td>'||html不会写的话网上查吧,就不举例子了||'<br></td></tr></body></html>';
-------------
utl_smtp.write_data(conn,utl_tcp.crlf);
utl_smtp.write_raw_data(conn,utl_raw.cast_to_raw(convert(v_body, 'zhs16gbk')));
utl_smtp.close_data(conn);
utl_smtp.quit(conn);
end send_mail;
end send_email_pak;
以上
Oracle邮件发送(内容中带有收件人独有信息)的更多相关文章
- oracle 邮件发送
CREATE OR REPLACE PROCEDURE PRC_sendmail(p_receiver VARCHAR2, -- 邮件接收人 ...
- JavaMail邮件发送不成功的那些坑人情况及分析说明
[我的Segmentfault原文]https://segmentfault.com/a/1190000008030346 前言 JavaMail的使用本身并不难,网上有不少案例,简单易懂,而且有 ...
- .NET开发邮件发送功能的全面教程(含邮件组件源码)
今天,给大家分享的是如何在.NET平台中开发“邮件发送”功能.在网上搜的到的各种资料一般都介绍的比较简单,那今天我想比较细的整理介绍下: 1) 邮件基础理论知识 2) ...
- .NET开发邮件发送功能
.NET开发邮件发送功能 今天,给大家分享的是如何在.NET平台中开发“邮件发送”功能.在网上搜的到的各种资料一般都介绍的比较简单,那今天我想比较细的整理介绍下: 1) 邮件基础理论知 ...
- iOS开发-邮件发送
Web开发的时候邮箱注册登录是必不可少的,手机号可以更换,不过相对而言,邮箱只是用于比较重要的时候用到,比如找工作的时候必填的邮箱,注册网站会员的邮箱验证.现在的手机和Web的其实操作是一样的,大多数 ...
- Java Mail 邮件发送简单封装
上一篇文章我们用写了一个Java Mail 的Demo,相信你已经可以用那个例子来发送邮件了.但是Demo 有很多的问题. 首先每次发送需要配置的东西很多,包括发件人的邮箱和密码.smtp服务器和SM ...
- 测试开发【提测平台】分享11-Python实现邮件发送的两种方法实践
微信搜索[大奇测试开],关注这个坚持分享测试开发干货的家伙. 按照开发安排,本篇本应该是关于提测页面的搜索和显示实现,怕相似内容疲劳,这期改下内容顺序,将邮件服务的相关的提前,在之前的产品需求和原型中 ...
- C#调用smtp邮件发送几个大坑
1.网易.新浪邮箱新增了一个叫“授权码”的东西,开通smtp服务时,必须开启授权码,并且邮件发送代码中也需要加上授权码,如下代码: //指定邮箱账号和密码,需要注意的是,这个密码是你在邮箱设置里开启服 ...
- SpringBoot系列(十四)集成邮件发送服务及邮件发送的几种方式
往期推荐 SpringBoot系列(一)idea新建Springboot项目 SpringBoot系列(二)入门知识 springBoot系列(三)配置文件详解 SpringBoot系列(四)web静 ...
- Spring邮件发送1
注意:邮件发送code中,邮件服务器的申请和配置是比较主要的一个环节,博主这里用的是QQ的邮件服务器.有需要的可以谷歌.百度查下如何开通. 今天看了下Spring的官方文档的邮件发送这一章节.在这里记 ...
随机推荐
- vue peek 解决了 vue-template 加载 相对目录 ./components 组件内容 vscode
点击组件跳转,vue-helper 带@的能跳转,相对目录的不能跳转.vue peek 解决了这个问题.
- Kotlin学习快速入门(9)—— 密封类的使用
原文地址: Kotlin学习快速入门(9)-- 密封类的使用 - Stars-One的杂货小窝 代码逻辑中,很多时候我们会需要分支语句,来根据数据的情况走不同的处理逻辑,而密封类就是在这种情况下,方便 ...
- 快速将json装DTO的GsonFormatPlus插件使用
参考:https://www.jianshu.com/p/8fb0e4274436 https://blog.csdn.net/qq_43039260/article/details/12676582 ...
- FFmpeg命令行之ffmpeg
一.简述 ffmpeg是一个非常强大的工具,它可以转换任何格式的媒体文件,并且还可以用自己的AudioFilter以及VideoFilter进行处理和编辑.有了它,我们就可以对媒体文件做很多我们想做的 ...
- vue基础知识和原理(二)
1.13 列表渲染 v-for指令 用于展示列表数据 语法:v-for="(item, index) in xxx" :key="yyy" 可遍历:数组.对象. ...
- linux文件编辑
1.VIM基本概述 1.什么是VIM? vi和vim是Linux下的一个文本编辑工具.(可以理解为windows的记事本,或word文档) 2.为什么要使用VIM? 因为Linux系统一切皆为文件,而 ...
- 如何从容的打包上传图片对象--File,Blob,BASE64详解及转换方法
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 File() File() 构造器创建新的 File 对象实例. 语法 var myFile = new File(bits, name[ ...
- vue中类tabs左右滑动
效果图 思路 给定一个变量用来记录滚动了几列,每滚动一次加1滚动一列,监听页面滚动父级元素宽度改变,重新设置滚动的距离(放在计算属性中让其自动计算) <template> <div ...
- SpringBoot 常用注解总结
核心注解 1. @SpringBootApplication 主要用于开启自动配置,它也是一个组合注解,主要组合了 @SpringBootConfiguration.@EnableAutoConfig ...
- C++获取任务管理器信息,封装成DLL,C#调用例子
C++代码 pch.h // pch.h: 这是预编译标头文件. // 下方列出的文件仅编译一次,提高了将来生成的生成性能. // 这还将影响 IntelliSense 性能,包括代码完成和许多代码浏 ...