Я загрузил SwiftMailer 4.1.6 для отправки электронной почты с помощью Gmail. Для этой цели я написал следующий код.
<?php require_once 'swiftmailer/lib/swift_required.php'; $transport = Swift_SmtpTransport::newInstance('smtp.gmail.com', 465, "ssl") ->setUsername('jomit.jmt@gmail.com') ->setPassword('***********'); $mailer = Swift_Mailer::newInstance($transport); $message = Swift_Message::newInstance('Wonderful Subject') ->setFrom(array('jomit.jmt@gmail.com' => 'Jomit Jose')) ->setTo(array('jomit.jmt@gmail.com' => 'Jomit Jose')) ->setBody('This is the text of the mail send by Swift using SMTP transport.'); $numSent = $mailer->send($message); printf("Sent %d messages\n", $numSent);
и это привело к следующей ошибке:
Fatal error: Uncaught exception 'Swift_TransportException' with message 'Connection could not be established with host smtp.gmail.com [Permission denied #13]' in /home/jomit/public_html/email_test/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php:266 Stack trace: #0 /home/jomit/public_html/email_test/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php(66): Swift_Transport_StreamBuffer->_establishSocketConnection() #1 /home/jomit/public_html/email_test/swiftmailer/lib/classes/Swift/Transport/AbstractSmtpTransport.php(117): Swift_Transport_StreamBuffer->initialize(Array) #2 /home/jomit/public_html/email_test/swiftmailer/lib/classes/Swift/Mailer.php(79): Swift_Transport_AbstractSmtpTransport->start() #3 /home/jomit/public_html/email_test/test.php(16): Swift_Mailer->send(Object(Swift_Message)) #4 {main} thrown in /home/jomit/public_html/email_test/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php on line 266
Что могло пойти не так?
У нас была эта проблема, и причина оказалась настройкой SELinux, которая предотвращает появление Apache и, следовательно, PHP для открытия любых исходящих соединений сокетов. Мы отключили его, но забыли параметр -P
чтобы он был возвращен при следующей перезагрузке. Если вы используете CentOS, RHEL или какой-либо другой дистрибутив SELinux, это вероятная причина проблемы.
Ограничение соединения можно отключить с помощью этой команды:
setsebool -P httpd_can_network_connect on