博客
关于我
thinkphp-实现邮件发送
阅读量:607 次
发布时间:2019-03-11

本文共 3003 字,大约阅读时间需要 10 分钟。

参考:

目标:使用thinkphp5.0 实现邮件发送

步骤:

第一步:进入163邮箱,开启SMTP服务、POP3服务、IMAP服务

这里写图片描述

第二步:开通客户端授权码,密码只显示一次必须记住

这里写图片描述

第三步:下载phpmailer 压缩包

下载链接: 密码:hrzb

解压之后,把 thinkphp5 的项目中的 extend 目录下新建一个 phpmailer 文件夹,然后把class.phpmailer.phpclass.smtp.php文件复制到phpmailer目录下。

第四步:开启openssl扩展

首先查看是否存在php_openssl.dll扩展(没有就去下载安装指定目录,例如:F:\xampp\php\ext),直接使用every搜索就行;

确定存在以后打开php.ini配置文件
搜索extension=php_openssl.dll去掉注释

第五步:由于thinkphp5中的extend下的扩展类使用的是命名空间,所以必须在class.phpmailer.phpclass.smtp.php最开头加上namespace phpmailer;

这里写图片描述

第六步:在class.phpmailer.php中的2315行使用到了php的Exception异常类,在thinkphp框架中直接继承,thinkphp找不到Exception所以要修改如下;

这里写图片描述

第七步:修改class.phpmailer.php文件名为phpmailer.phptp5下的extend扩展类库中文件命名只能这样命名才能使用use加载

第八步:控制器中添加use引入

use phpmailer\phpmailer;

实例:在index空间中的index控制器里的index方法发送邮件:

isSMTP();// 使用SMTP服务 $mail->CharSet = "utf8";// 编码格式为utf8,不设置编码的话,中文会出现乱码 $mail->Host = "smtp.163.com";// 发送方的SMTP服务器地址 $mail->SMTPAuth = true;// 是否使用身份验证 $mail->Username = "*******@163.com";// 发送方的163邮箱用户名 $mail->Password = "zhl005";// 客户端授权密码 $mail->SMTPSecure = "ssl";// 使用ssl协议方式 $mail->Port = 994;// 163邮箱的ssl协议方式端口号是465/994 $mail->setFrom("******@163.com","zhl");// 设置发件人信息 $mail->addAddress($toemail,'收件');// 设置收件人信息 $mail->addReplyTo("*******@163.com","回复");// 设置回复人信息 //$mail->addCC("xxx@163.com");// 设置邮件抄送人,可以只写地址,上述的设置也可以只写地址(这个人也能收到邮件) //$mail->addBCC("xxx@163.com");// 设置秘密抄送人(这个人也能收到邮件) //$mail->addAttachment("bug0.jpg");// 添加附件 $mail->Subject = "邮件发送";// 邮件标题 $mail->Body = "邮件内容";// 邮件正文 //$mail->AltBody = "This is the plain text纯文本";// 这个是设置纯文本方式显示的正文内容,如果不支持Html方式,就会用到这个,基本无用 if(!$mail->send()){ // 发送邮件 echo "邮件发送失败
"; echo "邮件错误: ".$mail->ErrorInfo;// 输出错误信息 }else{ echo '发送成功'; } }}

到此邮件发送成功结束。

备注:如果出现SMTP Error: Data not accepted 邮件发送失败,表示你使用了邮件禁止的过滤字,解决方法很简单,只要换一下就好了。

例如:

这里写图片描述

这里写图片描述

实例2:

// 投诉建议邮件发送机制    public function tsjy_to(){           // return '1231';//        dump($_POST);die();        $mail = new PHPMailer();        $mail->isSMTP();// 使用SMTP服务        $mail->CharSet = "utf8";// 编码格式为utf8,不设置编码的话,中文会出现乱码        $mail->Host = "smtp.163.com";// 发送方的SMTP服务器地址        $mail->SMTPAuth = true;// 是否使用身份验证        $mail->Username = "*******@163.com";// 发送方的163邮箱用户名        $mail->Password = "*******";// 客户端授权密码        $mail->SMTPSecure = "ssl";// 使用ssl协议方式        $mail->Port = 994;// 163邮箱的ssl协议方式端口号是465/994        $mail->setFrom("*******@163.com","集团网投诉邮件");// 设置发件人信息        $mail->addAddress("********@******.com",'******');// 设置收件人信息        $mail->Subject = $_POST['title'];// 邮件标题        $mail->Body = "用户:".$_POST['phone']."\n"."邮箱:".$_POST['email']."\n"."投诉行业:".$_POST['interest']."\n"."内容:".$_POST['centent'];// 邮件正文        //$mail->AltBody = "This is the plain text纯文本";// 这个是设置纯文本方式显示的正文内容,如果不支持Html方式,就会用到这个,基本无用        if(!$mail->send()){  // 发送邮件            echo "邮件发送失败
"; echo "邮件错误: ".$mail->ErrorInfo;// 输出错误信息 }else{ echo '发送成功'; } }
你可能感兴趣的文章
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>