laravel 邮件发送消息

本文介绍如何在Laravel框架中配置和使用163及QQ邮箱服务发送邮件,包括SMTP配置、邮件发送方法及邮件中包含图片和附件的具体实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:配置

如果用QQ和163邮箱的话  记得开启POP3和SMTP服务

 

配置文件:

laravel/config/mail.php
.env
以.env为准 .env会覆盖mail.php的配置,当.env里相应的配置为空的时候,才会取得mail.php的配置
MAIL_DRIVER=smtp
MAIL_HOST=smtp.163.com
MAIL_PORT=465
MAIL_USERNAME=你的163邮箱地址
MAIL_PASSWORD=你的163邮箱地址对应的授权密码(不是登录密码,千万别搞错了)
MAIL_ENCRYPTION=ssl

配置说明:

  1. driver用于配置默认的邮件发送驱动,Laravel支持多种邮件驱动方式,包括smtp、Mailgun、Maildrill、Amazon SES、mail和sendmail,Mailgun和Amazon SES都是收费的Maildrill目前不支持中国区用户,这三个都是第三方邮件服务。mail驱动使用PHP提供的mail函数发送,sendmail驱动通过Sendmail/Postfix(Linux)提供的命令发送邮件,smtp驱动通过支持ESMTP的SMTP发送邮件。
    就目前状况来看,使用smtp是最明智的选择,mail不安全,sendmail需要安装配置Sendmail/Postfix,其他要么付费要么不能用。
  2. host是邮箱所在主机,比如我们使用163邮箱,对应值是smtp.163.com,使用QQ邮箱的话,对应值是smtp.qq.com
  3. port用于配置邮箱发送服务端口号,比如一般默认值是25,但如果设置SMTP使用SSL加密,该值为465。
  4. from配置项包含address和name,前者表示发送邮箱,后者表示发送邮件使用的用户名。
  5. encryption表示加密类型,可以设置为null表示不使用任何加密,也可以设置为tls或ssl。
  6. username表示邮箱账号,比如*****@1163.com
  7. password表示上述邮箱登录对应登录密码。注意QQ邮箱的话应该开启POP3|SMTP服务时给的密钥。
  8. sendmail是在设置driver为sendmail时使用,用于指定sendmail命令路径。
Mail::send();需要传三个参数,第一个为引用的模板,第二个为给模板传递的变量,第三个为一个闭包,参数绑定Mail类的一个实例。

Mailer::send文档
Mailer:: failures文档

 1     /**
 2      * 发送邮件
 3      */
 4     public function sendEmil()
 5     {
 6         $message = '你想成为曼城的球迷吗?';
 7         $name = '独孤剑';
 8         $to = '*********@qq.com';
 9         $subject = '马云给你免费购物';
10         $imgPath = 'http://d.hiphotos.baidu.com/zhidao/pic/item/1ad5ad6eddc451da4ab93e2bb0fd5266d11632a6.jpg';
11         //Mail::send() 的返回值为空,所以可以其他地方进行判断
12         Mail::send('emails.test',['content' => $message,'name' => $name,'imgPath' =>$imgPath],function ($message) use ($to,$subject){
13             $message->to($to)->subject($subject);
14         });
15         if (count(Mail::failures())<1)
16         {
17             echo '发送邮件成功,请查收';
18         }else{
19             echo '发送邮件失败,请重试';
20         }
21     }

 

邮件中发送附件

  1. 网络图片
    当然,可以在模板直接应用静态文件;但灵活性差,使用embed方法更灵活。
{{$name}}:你好,这是一封测试邮件,内容:{{$content}}
<br>
<img src="{{$message->embed($imgPath)}}">

 

 
  1. 本地图片
    本地图片引用需要使用到Storage类,模板方法略有不同,在Storage/images文件夹中有一张图片。
    embedData()两个参数,第一个为图片,第二个为自定义图片名称。
# test.blade.php
{{$name}},这是一封测试邮件
<br>
<img src="{{$message->embedData($image,'我的自拍照.jpg')}}"> 
# MailController.php
 public function send(){ $image = Storage::get('images/obama.jpg'); Mail::send('emails.test',['image'=>$image],function($message){ $to = '282584778@qq.com'; $message->to($to)->subject('[本地图片测试]'); }); if(count(Mail::failures()) < 1){ echo '发送邮件成功,请查收!'; }else{ echo '发送邮件失败,请重试!'; } } 

邮件附件

public function sendFile(){ $name = '王宝花'; Mail::send('emails.test',['name'=>$name],function($message){ $to = '282584778@qq.com'; $message->to($to)->subject('邮件主题'); $attachment = storage_path('app/files/test.txt'); // 在邮件中上传附件 $message->attach($attachment,['as'=>'中文文档.txt']); }); } 

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

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

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

 

 

转载于:https://www.cnblogs.com/xzj8023tp/p/9309642.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值