Laravel学习笔记-邮件发送功能

2020-11-18  本文已影响0人  赵客缦胡缨v吴钩霜雪明

最近由于项目需求,要在项目中使用发邮件功能,就打算使用Laravel框架自带的SwiftMailer。

laravel自带SwiftMailer库,集成了多种邮件API,可以很方便的实现邮件的发送。

本次使用到的是SMTP(Simple Message Transfer Protocol)简单邮件传输协议,通常理解为邮件发送服务器。

以QQ邮箱为例

使用QQ邮箱的话,需要开启POP3和SMTP服务(QQ邮箱登录=》选择设置=》账户=》下拉找到图2)。
使用企业邮箱不用开启SMTP,因为企业邮箱自带,如果配置有问题去查一下是否关闭安全登录(企业邮箱)
开启方式如下:

当开启成功会生成密钥,这个东西会在配置中用:


配置laravel .env文件

MAIL_DRIVER=smtp
MAIL_HOST=smtp.qq.com
MAIL_PORT=465
MAIL_USERNAME=********@qq.com
MAIL_PASSWORD=qq邮箱此处填写上图产生的授权码
MAIL_FROM_NAME=邮箱的名称
MAIL_ENCRYPTION=ssl

配置laravel config/mail.php文件

这文件是laravel自带的文件,如果没有需求,内容可不动

return [
    'driver' => env('MAIL_DRIVER', 'smtp'),
    'host' => env('MAIL_HOST', 'smtp.mailgun.org'),
    'port' => env('MAIL_PORT', 587),
    'from' => [
        'address' => env("MAIL_USERNAME", ""),
        'name' => env("MAIL_FROM_NAME")
    ],
    'encryption' => env('MAIL_ENCRYPTION'),
    'username' => env('MAIL_USERNAME'),
    'password' => env('MAIL_PASSWORD'),
    'sendmail' => '/usr/sbin/sendmail -bs',
    'pretend' => env('MAIL_PRETEND', false),
];

参数解释

开始代码之旅

生成控制器

php artisan make::controller MailController

配置路由

Route::any('mail/send','MailController@send');

在app/Http/Controllers生成了一个MailController控制器,如下所示:

<?php 
    namespace App\Http\Controllers; 
    use App\Http\Requests; 
    class MailController extends Controller { 
        //
     }

编辑上面控制器,加入以下的逻辑处理:

use Mail;
class MailController{ 
    public function send() {
     $name = '我发的第一份邮件'; 
     // Mail::send()的返回值为空,所以可以其他方法进行判断 
     Mail::send('emails.test',['name'=>$name],function($message){ 
     $to = '123456789@qq.com'; $message ->to($to)->subject('邮件测试'); 
     }); 
     // 返回的一个错误数组,利用此可以判断是否发送成功
      dd(Mail::failures());
    } 
} 

Mail::send();需要传三个参数,第一个为引用的模板,第二个为给模板传递的变量(邮箱发送的文本内容),第三个为一个闭包,参数绑定Mail类的一个实例。

在resources/emails下创建一个模板文件。

{{$name}} hello world。

好,现在在服务器上进行测试了,在地址栏输入http://localhost/mail/send(自己的访问地址),发送成功。

1. 发送纯文本邮件

Mail::raw('测试', function ($message) {
    $to = '123456789@qq.com';
    $message ->to($to)->subject('纯文本信息邮件测试');
});

2.邮件中发送附件

发生图片:

{{$name}},这是一封测试邮件
<br>
<img src="{{$message->embedData($image,'test.jpg')}}">
public function send(){ 
    $image = Storage::get('images/obama.jpg'); //本地文件
    //$image = 'http://www.baidu.com/sousuo/pic/sdaadar24545ssqq22.jpg';//网上图片
    Mail::send('emails.test',['image'=>$image],function($message){ 
        $to = '123456789@qq.com';
        $message->to($to)->subject('图片测试'); 
    }); 
    if(count(Mail::failures()) < 1){
     echo '发送邮件成功,请查收!'; 
    }else{
     echo '发送邮件失败,请重试!';
    } 
}

3. 邮件附件

public function sendFile(){ 
    $name = '我发的第一份邮件'; 
    Mail::send('emails.test',['name'=>$name],function($message){ 
        $to = '123456789@qq.com';
        $message->to($to)->subject('邮件测试'); 
        $attachment = storage_path('xls/files/test.xls');
         // 在邮件中上传附件 
        $message->attach($attachment,['as'=>'中文文档.xls']); 
    }); 
} 

$message的attach方法上传附件,该方法第一个参数是附件地址,第二个参数为一些额外参数,这里我们通过as指定附件在邮件中的显示名称。

测试如果显示文件名乱码的话,就这样写

$message->attach($attachment,['as'=>"=?UTF-8?B?".base64_encode('中文文档')."?=.xls"]);

好了,现在我们的邮件发生功能已经基本满足需求了,打完收工!

上一篇 下一篇

猜你喜欢

热点阅读