Laravel5.0+框架邮件发送功能实现方法图文与实例详解


Posted in PHP onApril 23, 2019

本文实例讲述了Laravel5.0+框架邮件发送功能实现方法。分享给大家供大家参考,具体如下:

I. 背景

  • 近期在接触传说中最优雅的 PHP 框架——Laravel,学习了一下邮件发送功能,在此分享一下
  • 测试环境:Laravel 5.2.45,Laravel 5.5
  • 使用协议:SMTP 邮件传输协议
  • 对于 ThinkPHP 框架框架的邮件发送可参考文章 ThinkPHP 框架下邮件发送功能

II. 功能开发过程

  • 此处以 网易(163.com)邮箱为例。

一、前期准备

(1).首先对 SMTP 的知识稍作了解

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

(2).开启邮箱 SMTP 服务

  • 以 163.com 邮箱为例,点击上方导航栏的“设置”,选择“POP3/SMTP/IMAP”进行下面的设置,着重记下服务器地址(SMTP 服务器:smtp.163.com

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

  • 然后点击“客户端授权密码”进行权限设置,一般会进行短信的验证,并记录下自己设定的授权登录密码,后面的代码中需要用到。

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

二、代码实现

(1).修改配置文件 mail.php

  • 文件位置位于 config/mail.php
  • 修改其中的 “from” 信息,以本人为例,address 为发送方邮箱账号,name 为称谓
'from' => ['address' => '1xxxxxxx@163.com', 'name' => '逗比2号'],

(2).修改配置文件 .env

MAIL_DRIVER=smtp
MAIL_HOST=smtp.163.com
MAIL_PORT=25
MAIL_USERNAME=1xxxxxxx@163.com
MAIL_PASSWORD=xxxxx
MAIL_ENCRYPTION=null
  • 注意配置信息的填写:MAIL_USERNAME,MAIL_PASSWORD 为前期准备中记下的163邮箱账号及客户端授权密码(非登录密码)

  • MAIL_PORT 为默认端口号,如果配置 MAIL_ENCRYPTION = ssl 时,端口号需要更改为 465

(3).补充路由信息

Route::any('mail', 'TestController@mail');

(4).控制器代码编写

  • 基本的代码编辑如下
  • 注意,本人发现网上的介绍有出入,有的是使用 Mail 类,推测应该是版本不同的原因,此处针对 5.2.45、5.5 版本进行的测试
  • 附录 TestController.php 源代码以供参考
<?php
namespace App\Http\Controllers;
use Illuminate\Mail\Mailer;

class TestController extends Controller
{
 private $mailer;

 public function __construct(Mailer $mailer)
 {
  $this->mailer = $mailer;
 }
 /**
  * 发送邮件
  */
 public function mail(){
  //测试数据
  $viewData = ['title' => '你若盛开,清风自来','author' => '木心'];
  $emailData = [
   'content' => '从前的日色变得慢 车 马 邮件 都慢',
   'subject' => '这是邮件主题,希望您能支持!',//邮件主题
   'addr' => 'xxxxxxxxx@qq.com',//邮件接收地址
  ];
  $this->sendText($emailData);
  //$this->sendHtml('mail',$viewData,$emailData);
  //TODO $tag 判断发送是否成功,进行后续代码开发
  return view('mail',['title' => '你若盛开,清风自来','author' => '木心']);
 }

 /**
  * 发送纯文本 邮件
  * @param $emailData 邮件数据
  */
 public function sendText($emailData){
  //此处为文本内容
  $tag = $this->mailer
   ->raw($emailData['content'],
    function ($message)use ($emailData){
     $message->subject($emailData['subject']);
     $message->to($emailData['addr']);
    });
  return $tag;
 }
 /**
  * 发送自定义网页
  * @param $emailData 邮件数据
  * @param $viewPage html视图
  * @param $viewData html传输数据
  */
 public function sendHtml($viewPage,$viewData,$emailData){
  $tag = $this->mailer
   ->send($viewPage,$viewData,
    function ($message) use ($emailData){
     $message->subject($emailData['subject']);
     $message->to($emailData['addr']);
    });
  return $tag;
 }
}

三、 代码说明

(1).方法 sendText()

  • 此方法为发送纯文本邮件的功能实现,调用此方法发送的邮件截图如下:

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

(2).方法 sendHtml()

  • 此方法为自定义格式邮件发送的功能实现
  • 实现的前提需要有设计界面,代码中举例为我简单设计的 mail.blade.php 参考代码如下:
<html>
<style>
 *{
  font-family: 楷体;
 }
</style>
<h2>{{$title}}</h2>
![]({{asset('uploads/20170902/59aa05723e35d.jpg')}})
<pre>
  从前的日色
  变得慢
  车 马 邮件
   都慢
 一生只够爱一个人
    --{{$author}}
</pre>
</html>
  • 调用此方法发送的邮件截图如下:

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

III. 补充

(1).另一种简单写法

  • 其实可提供一种更简单的写法,与上面所处理的 raw(),send() 方法类似,举例:
use Illuminate\Support\Facades\Mail;

$tag = Mail::raw('你好,我们已经准备好了',function ($message){
   $message->to('9xxxxxxxxxx@qq.com');
  });
  • 不过,测试发现会有如下报错:

FatalErrorException in ClassLoader.php line 373:Maximum function nesting level of '100' reached, aborting!

  • 但是前面的第一种代码方案,不会出现此问题,并且邮件发送响应快一些(或许错觉),然而,此代码如果放在队列中执行,测试发现不做任何修改也是可以实现…

  • 原因和解决方案,请参考文章 - PHP中的函数嵌套层数限制

(2).554 邮件发送报错

  • 有时邮件发送时,会有如下报错,例如 554 多表示邮件发送过多被系统禁止了,具体信息可通过提示信息中的网址进行查询.

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

Laravel5.0+框架邮件发送功能实现方法图文与实例详解

  • 具体代码可自行优化,有问题建议多多谷歌,还是能帮到不少忙的.

(3). post 请求500报错

  • 注意一点:laravel框架默认要求表单提交时需要添加
{{ csrf_field() }}

附:PHP中的函数嵌套层数限制

访问PHP网站如下以下错误:

 Fatal error: Maximum function nesting level of '100' reached, aborting!

原因分析:

这个问题是由于你启用了xdebug,而xdebug默认设置了函数最大嵌套数为100

解决办法:

找到php.ini文件,找到xdebug
在最后加上xdebug.max_nesting_level = 500 (这个数最好大于100即可)

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

PHP 相关文章推荐
php反弹shell实现代码
Apr 22 PHP
PHP n个不重复的随机数生成代码
Jun 23 PHP
php中url函数介绍及使用示例
Feb 13 PHP
PHP批量生成静态HTML的简单原理和方法
Apr 20 PHP
php实现字符串首字母大写和单词首字母大写的方法
Mar 14 PHP
PHP常见的6个错误提示及解决方法
Jul 07 PHP
PHP中字符串长度的截取用法示例
Jan 12 PHP
Laravel中encrypt和decrypt的实现方法
Sep 24 PHP
PHP封装curl的调用接口及常用函数详解
May 31 PHP
PHP基于openssl实现的非对称加密操作示例
Jan 11 PHP
PHP封装mysqli基于面向对象的mysql数据库操作类与用法示例
Feb 25 PHP
php文件上传原理与实现方法详解
Dec 20 PHP
一文掌握PHP Xdebug 本地与远程调试(小结)
Apr 23 #PHP
ThinkPHP3.2.3框架邮件发送功能图文实例详解
Apr 23 #PHP
PHP信号处理机制的操作代码讲解
Apr 19 #PHP
CentOS7编译安装php7.1的教程详解
Apr 18 #PHP
浅析PHP 中move_uploaded_file 上传中文文件名失败
Apr 17 #PHP
Laravel框架集成UEditor编辑器的方法图文与实例详解
Apr 17 #PHP
Laravel5框架自定义错误页面配置操作示例
Apr 17 #PHP
You might like
php adodb介绍
2009/03/19 PHP
调整优化您的LAMP应用程序的5种简单方法
2011/06/26 PHP
PHP实现打包下载文件的方法示例
2017/10/07 PHP
PHP实现求连续子数组最大和问题2种解决方法
2017/12/26 PHP
php 中self,this的区别和操作方法实例分析
2019/11/04 PHP
js压缩工具 yuicompressor 使用教程
2010/03/31 Javascript
基于jquery的loading效果实现代码
2010/11/05 Javascript
jQuery学习笔记之Helloworld
2010/12/22 Javascript
myFocus slide3D v1.1.0 使用方法与下载
2011/01/12 Javascript
js 阻止子元素响应父元素的onmouseout事件具体实现
2013/12/23 Javascript
js仿土豆网带缩略图的焦点图片切换效果实现方法
2015/02/23 Javascript
简述JavaScript的正则表达式中test()方法的使用
2015/06/16 Javascript
js实现圆盘记速表
2015/08/03 Javascript
JavaScript常用字符串与数组扩展函数小结
2016/04/24 Javascript
浅谈JS使用[ ]来访问对象属性
2016/09/21 Javascript
JS控制TreeView的结点选择
2016/11/11 Javascript
基于JQuery实现的跑马灯效果(文字无缝向上翻动)
2016/12/02 Javascript
详解vuelidate 对于vueJs2.0的验证解决方案
2017/03/09 Javascript
Node.js中的child_process模块详解
2018/06/08 Javascript
详解Koa中更方便简单发送响应的方式
2018/07/20 Javascript
详解VSCode配置启动Vue项目
2019/05/14 Javascript
js对象属性名驼峰式转下划线的实例代码
2020/09/17 Javascript
uniapp微信小程序:key失效的解决方法
2021/01/20 Javascript
Python函数嵌套实例
2014/09/23 Python
对numpy中的transpose和swapaxes函数详解
2018/08/02 Python
利用Python求阴影部分的面积实例代码
2018/12/05 Python
Python下简易的单例模式详解
2019/04/08 Python
详解Python中的各种转义符\n\r\t
2019/07/10 Python
Python使用多进程运行含有任意个参数的函数
2020/05/02 Python
在python3.9下如何安装scrapy的方法
2021/02/03 Python
顶碗少年教学反思
2014/02/21 职场文书
2014年保卫科工作总结
2014/12/05 职场文书
小学语文教师年度考核个人总结
2015/02/05 职场文书
会计工作能力自我评价
2015/03/05 职场文书
实习报告范文
2019/07/30 职场文书
如何理解Vue前后端数据交互与显示
2021/05/10 Vue.js