这篇文章主要给大家介绍了关于Laravel6.18.19如何优雅的切换发件账户的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Laravel6.18.19具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
前言
在做一个通知系统时,业务需求,根据不同场景使用不同的账户发送邮件,laravel默认只支持一个邮箱发邮件。不满实际情况,使用Config::set()方法动态设置账户后,可以成功发送邮件,再次set无法再次修改发件账户。
查阅多个资料的值,需要重新设置SwiftMailer。
方法如下:
创建邮箱账户配置文件/config/my_emails.php
<?php
return [
'emails' => [
'a' => [
'email' => 'a@188.com',
'password' => '专属客户端密码',
'smtp' => 'smtp.188.com',
'port' => '465',
'encryption' => 'ssl',
'name' => '靓仔A',
],
'b' => [
'email' => 'b@188.com',
'password' => '专属客户端密码',
'smtp' => 'smtp.188.com',
'port' => '994',
'encryption' => 'ssl',
'name' => '靓女b',
],
],
];
接下来创建切换助手类
<?php
namespace App\Mail;
use Illuminate\Support\Facades\Mail;
class MailHelper
{
public static function setAccount($accountName)
{
$transport = new \Swift_SmtpTransport(
config("my_emails.emails.{$accountName}.smtp"),
config("my_emails.emails.{$accountName}.port"),
config("my_emails.emails.{$accountName}.encryption")
);
$transport->setUsername(config("my_emails.emails.{$accountName}.email"));
$transport->setPassword(config("my_emails.emails.{$accountName}.password"));
$mailer = new \Swift_Mailer($transport);
Mail::setSwiftMailer($mailer);
Mail::alwaysFrom(config("my_emails.emails.{$accountName}.email"), config("my_emails.emails.{$accountName}.name"));
}
}
实际使用如下:
<?php
MailHelper::setAccount('a');
Mail::to('boy@163.com')->send(new TestMail());
MailHelper::setAccount('b');
Mail::to('girl@163.com')->send(new TestMail());
总结
到此这篇关于Laravel6.18.19如何优雅的切换发件账户的文章就介绍到这了,更多相关Laravel6.18.19切换发件账户内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
沃梦达教程
本文标题为:Laravel6.18.19如何优雅的切换发件账户


基础教程推荐
猜你喜欢
- Laravel 解决composer相关操作提示php相关异常的问题 2023-03-08
- PHP基于反射机制实现自动依赖注入的方法详解 2022-10-02
- php+mysql开发的最简单在线题库(在线做题系统)完整案例 2023-01-04
- PHP laravel使用自定义邮件类实现发送邮件 2023-07-03
- php生成短网址/短链接原理和用法实例分析 2023-04-20
- php如何获取当前日期和星期 2024-12-06
- php去除deprecated的实例方法 2022-09-02
- Laravel修改验证提示信息为中文的示例 2023-03-08
- PHP字符串函数系列之nl2br(),在字符串中的每个新行 (\n) 之前插入 HTML 换行符br 2024-03-28
- PHP采用get获取url汉字出现乱码的解决方法 2024-03-28