Laravel6 优雅的切换发件账户-LMLPHP

前言

在做一个通知系统时,业务需求,根据不同场景使用不同的账户发送邮件,laravel默认只支持一个邮箱发邮件。不满实际情况,使用Config::set()方法动态设置账户后,可以成功发送邮件,再次set无法再次修改发件账户。

方法如下:

创建邮箱账户配置文件/config/my_emails.php


<?php
return [
 'emails' => [
  'a' => [
   'email' => '[email protected]',
   'password' => '专属客户端密码',
   'smtp' => 'smtp.188.com',
   'port' => '465',
   'encryption' => 'ssl',
   'name' => '靓仔A',
  ],
  'b' => [
   'email' => '[email protected]',
   '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('[email protected]')->send(new TestMail());
MailHelper::setAccount('b');
Mail::to('[email protected]')->send(new TestMail());
登录后复制

总结

到此这篇关于Laravel6.18.19如何优雅的切换发件账户的文章就介绍到这了

以上就是Laravel6 优雅的切换发件账户的详细内容,更多请关注Work网其它相关文章!

08-30 01:06