如何使用kettle发送邮件?

根据各自的需求创建转化任务,我这里就随便创建一个,从mysql表中抽取数据,过滤后将结果输出到文件中

您可能感兴趣的文章:

要使用kettle发送邮件,必须配置你的发件邮箱,因此要得到授权,我用的是163邮箱,就拿163邮箱来举例

准备:
1、设置邮箱独立密码
2、开启POP3/SMTP服务

这样配置好后运行就可以收到邮件了,不用每天手动发统计数据了。

图片 1

配置服务器

'MAIL_HOST' =>'smtp.163.com',//smtp服务器的名称
'MAIL_SMTPAUTH' =>TRUE, //启用smtp认证
'MAIL_USERNAME' =>'zha****22@163.com',//发件人的邮箱名
'MAIL_PASSWORD' =>'olagbqsyeyhilcwu',//163邮箱发件人授权密码
'MAIL_FROM' =>'zha****22@163.com',//发件人邮箱地址
'MAIL_FROMNAME'=>'天空还下着雪',//发件人姓名
'MAIL_CHARSET' =>'utf-8',//设置邮件编码
'MAIL_ISHTML' =>TRUE, // 是否HTML格式邮件

2.设置授权密码:在邮箱的左侧找到“客户端授权密码”,点击“开启”设置授权密码(要记住密码,后面要用),授权密码不能和登录密码一样,这个需要短信验证,如果觉得麻烦可以用QQ邮箱,QQ邮箱好像不用短信验证

QQ邮箱收发邮件

3.配置并发送邮件

html布局:

2.调用刚才创建的转换节点,找到你需要调度的转换,我刚才创建的转换时kettle

'MAIL_HOST' =>'smtp.qq.com',//smtp服务器的名称
'MAIL_SMTPAUTH' =>TRUE, //启用smtp认证
'MAIL_USERNAME' =>'541****34@qq.com',//发件人邮箱名
'MAIL_PASSWORD' =>'s****1241',//qq邮箱发件人独立密码
'MAIL_FROM' =>'541****34@qq.com',//发件人地址
'MAIL_FROMNAME'=>'恋狱',//发件人姓名(qq邮箱昵称)
'MAIL_CHARSET' =>'utf-8',//设置邮件编码
'MAIL_ISHTML' =>TRUE, // 是否HTML格式邮件

最近工作中遇到一个问题,如何将kettle统计好的数据每天早上发送给用户?以前都是每天早上过来手动写邮件然后再添加附件,觉得这样太弱了,就想着用kettle的自动发送邮件。通过查询资料终于实现了这个功能,于是就想拿出了与大家分享,拯救那些需要每天发送固定数据的基友。

用了很长时间去一步一步摸索,终于先在163
网易邮箱上测试成功了,下面就把这个过程分享给大家。

步骤二:创建转换任务

以上就是thinkphp实现163等邮箱收发邮件的方法,希望对大家的学习有所帮助。

配置地址

使用网易邮箱,当然要注册个账号,这个就不用我多说了,自己去注册。。。

1.可以在start中设置每天要发送的时间(这个很简单就不截图了)

其他无需改变,完成后不仅可以给QQ邮箱用户发送邮件,也可以给163邮箱用户发送邮件。

1.登录你的邮箱选择设置下的POP3/SMTP/IMAP

二、代码部分

选择 POP3/SMTP/IMAP

/*
 * 发送邮件
 * @param $to string
 * @param $title string
 * @param $content string
 * @return bool
 * */
function sendMail($to, $title, $content) {
 Vendor('PHPMailer.PHPMailerAutoload');
 $mail = new PHPMailer(); //实例化
 $mail->IsSMTP(); // 启用SMTP
 $mail->Host=C('MAIL_HOST'); //smtp服务器的名称(这里以QQ邮箱为例)
 $mail->SMTPAuth = C('MAIL_SMTPAUTH'); //启用smtp认证
 $mail->Username = C('MAIL_USERNAME'); //发件人邮箱名
 $mail->Password = C('MAIL_PASSWORD') ; //163邮箱发件人授权密码
 $mail->From = C('MAIL_FROM'); //发件人地址(也就是你的邮箱地址)
 $mail->FromName = C('MAIL_FROMNAME'); //发件人姓名
 $mail->AddAddress($to,"尊敬的客户");
 $mail->WordWrap = 50; //设置每行字符长度
 $mail->IsHTML(C('MAIL_ISHTML')); // 是否HTML格式邮件
 $mail->CharSet=C('MAIL_CHARSET'); //设置邮件编码
 $mail->Subject =$title; //邮件主题
 $mail->Body = $content; //邮件内容
 $mail->AltBody = "这是一个纯文本的身体在非营利的HTML电子邮件客户端"; //邮件正文不支持HTML的备用显示
 return($mail->Send());
}

步骤三:创建作业调度转换并发送邮件

图片 2

配置附件

function.php公共函数:

步骤一:邮箱授权

在进入正题这前先看下网易(163)邮箱的服务器地址和端口号:

如果有帮助到你请动动你的小手点个赞,谢谢,有什么问题可以留言交流

步骤一:

图片 3

add方法调用:

细心的同学在 class.phpmailer.php  class.pop3.php  class.smtp.php
这三个文件里看下默认的端口号,其SMTP的默认端口号是25 与
163下的SMTP发件服务器的非SSL协议端口号一样。

QQ邮箱收发件服务器地址和端口

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
</head>
<body>
 <form action="__URL__/add" method="post" enctype="multipart/form-data">
 收件人邮箱:<input type="text" name="mail"/>
 标题:<input type="text" name="title"/>
 内容<input type="text" name="content"/>
 <input class="button" type="submit" value="发送"/>
 </form>
</body>
</html>
public function add() {
 if(SendMail($_POST['mail'],$_POST['title'],$_POST['content'])) {
 $this->success('发送成功!');
 } else {
 $this->error('发送失败');
 }
}

图片 4

图片 5

配置:

图片 6

一、前期准备

注册完之后,就要去开启 POP3/SMTP/IMAP服务。
在开启服务时,需要客户端授权密码(这里需要手机验证,MD拐弯抹角的要手机号码)。

config.php 配置:

服务开启后,如果没有设置【姓名】,在写邮件发送时会提示设置【姓名】后才能发送邮件,当然也可以提前设置好。。

PHPMailer下载 (
下载后把PHPMailer放在Vendor目录下,另外文件中有很多不必要的东西,自己看着处理吧)

确定后会弹出下面这样的对话框,也会把这个授权密码发送你的短信里,记住这个授权密码一定要记住

做完以上工作后,接下来访问地址,通过表单向163(网易)邮箱发送邮件(如:发送给123456@163.com),也可以发送给自己,发送后,就会看到发送成功。下面你可以登录邮箱查看邮件。

图片 7

步骤二: