这篇文章主要给大家介绍了关于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如何优雅的切换发件账户
基础教程推荐
猜你喜欢
- php数组函数序列之array_sum() – 计算数组元素值之和 2024-01-15
- php实现数组筛选奇数和偶数示例 2024-02-05
- Yii框架连表查询操作示例 2023-02-13
- php实现构建排除当前元素的乘积数组方法 2022-11-23
- PHP+MySQL+sphinx+scws实现全文检索功能详解 2023-01-31
- 设定php简写功能的方法 2023-03-17
- PHP手机短信验证码实现流程详解 2022-10-18
- PHP实现文件下载【实例分享】 2024-04-27
- PHP实现抽奖系统的示例代码 2023-06-26
- PHP判断一个字符串是否是回文字符串的方法 2024-01-31
