public function send(Swift_Mime_SimpleMessage $message, &$failedRecipients = null)
{
$failedRecipients = (array) $failedRecipients;
if (!$this->transport->isStarted()) {
$this->transport->start();
}
$sent = 0;
try {
$sent = $this->transport->send($message, $failedRecipients);
} catch (Swift_RfcComplianceException $e) {
foreach ($message->getTo() as $address => $name) {
$failedRecipients[] = $address;
}
}
return $sent;
}
Это код от поставщика / swiftmailer / swiftmailer / lib / classes / Swift / Mailer. php
Сначала он работал нормально, также у нас есть другой проект, в котором используется та же библиотека и он отлично работает в этом проекте. Но в одном проекте в строке
$failedRecipients = (array) $failedRecipients;
это не дает никакой ошибки, просто действует так, как если бы эта строка вызывала возврат из функции. И поэтому электронная почта не отправляется. $ failedRecipients имеет значение null.
Php версия - 7.2.26, и она должна нормально работать, в другом проекте она такая же.
Обновление
Информация, запрошенная Zelay'da:
$ сообщение это :.
$ адрес будет строкой адреса электронной почты, имя будет нулевым, если код придет туда. Я взял их из $ message-> getTo (). Транспортным объектом является поставщик / swiftmailer / swiftmailer / lib / classes / Swift / Transport / SpoolTransport. php
Полный класс:
<?php
/*
* This file is part of SwiftMailer.
* (c) 2004-2009 Chris Corbyn
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/**
* Swift Mailer class.
*
* @author Chris Corbyn
*/
class Swift_Mailer
{
/** The Transport used to send messages */
private $transport;
/**
* Create a new Mailer using $transport for delivery.
*/
public function __construct(Swift_Transport $transport)
{
$this->transport = $transport;
}
/**
* Create a new class instance of one of the message services.
*
* For example 'mimepart' would create a 'message.mimepart' instance
*
* @param string $service
*
* @return object
*/
public function createMessage($service = 'message')
{
return Swift_DependencyContainer::getInstance()
->lookup('message.'.$service);
}
/**
* Send the given Message like it would be sent in a mail client.
*
* All recipients (with the exception of Bcc) will be able to see the other
* recipients this message was sent to.
*
* Recipient/sender data will be retrieved from the Message object.
*
* The return value is the number of recipients who were accepted for
* delivery.
*
* @param array $failedRecipients An array of failures by-reference
*
* @return int The number of successful recipients. Can be 0 which indicates failure
*/
public function send(Swift_Mime_SimpleMessage $message, &$failedRecipients = null)
{
$failedRecipients = (array) $failedRecipients;
if (!$this->transport->isStarted()) {
$this->transport->start();
}
$sent = 0;
try {
$sent = $this->transport->send($message, $failedRecipients);
} catch (Swift_RfcComplianceException $e) {
foreach ($message->getTo() as $address => $name) {
$failedRecipients[] = $address;
}
}
return $sent;
}
/**
* Register a plugin using a known unique key (e.g. myPlugin).
*/
public function registerPlugin(Swift_Events_EventListener $plugin)
{
$this->transport->registerPlugin($plugin);
}
/**
* The Transport used to send messages.
*
* @return Swift_Transport
*/
public function getTransport()
{
return $this->transport;
}
}