Изпращане на имейл със Swift Mailer, GMail и PHP, грешка при отказ на разрешение

Изтеглих SwiftMailer 4.1.6 за изпращане на имейл чрез Gmail. Бях написал следния код за тази цел.

<?php

require_once 'swiftmailer/lib/swift_required.php';

$transport = Swift_SmtpTransport::newInstance('smtp.gmail.com', 465, "ssl")
        ->setUsername('[email protected]')
        ->setPassword('***********');

$mailer = Swift_Mailer::newInstance($transport);
$message = Swift_Message::newInstance('Wonderful Subject')
        ->setFrom(array('[email protected]' => 'Jomit Jose'))
        ->setTo(array('[email protected]' => '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

Какво можеше да се обърка?


person Jomoos    schedule 02.04.2012    source източник
comment
опитайте порт, като използвате 443 вместо 465   -  person maxjackie    schedule 02.04.2012
comment
@maxjackie Ами сега! Това също води до същата грешка: Uncaught exception 'Swift_TransportException' with message 'Connection could not be established with host smtp.gmail.com [Permission denied #13]'   -  person Jomoos    schedule 02.04.2012
comment
Вашата PHP настройка поддържа ли SSL?   -  person Álvaro González    schedule 02.04.2012
comment
@ÁlvaroG.Vicario phpinfo() показва OpenSSL support enabled   -  person Jomoos    schedule 02.04.2012


Отговори (1)


Имахме този проблем и причината се оказа настройка на SELinux, която не позволява на Apache и следователно на PHP да отваря всякакви изходящи връзки на сокет. Бяхме го деактивирали, но забравихме параметъра -P, така че беше върнат при следващото рестартиране. Ако използвате CentOS, RHEL или друга дистрибуция, поддържаща SELinux, това е вероятна причина за проблема.

Ограничението за връзка може да бъде деактивирано с тази команда:

setsebool -P httpd_can_network_connect on
person Kaivosukeltaja    schedule 03.05.2013
comment
Добро решение. Работи за мен. - person user2681579; 27.01.2014
comment
Имах този проблем с инсталация на OrangeHRM. Отне ми време да намеря този скрит отговор. Благодаря много. - person jasperado; 24.07.2014
comment
След дълъг ден на търсене намерих тази публикация и тя реши проблема ми с това, че спреят за мухи не изпраща имейли, благодаря :) - person steabert; 20.08.2014
comment
Знам, че това е старо, но ако получите съобщение, че не могат да се зададат постоянни булеви стойности без управлявана политика, опитайте да изпълните sudo setsebool -P httpd_can_network_connect на - person DarthCaniac; 10.12.2015
comment
Това ме насочи в правилната посока. На моя PHP сървър имам изходящи връзки, които имат автоматично забранени IP адреси. Трябваше да вляза там и да разреша на всеки от тях за smtp.office365.com. - person jc.021286; 06.10.2016
comment
каква е командата за обръщане на setsebool -P httpd_can_network_connect on ?? - person oabarca; 05.01.2017