Silex / Swiftmailer / Exception не ловится

Есть код:

/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
try {
    $app['mailer']->send($message);
}
catch (Swift_TransportException $e) {
    print_r($e->getMessage());
}


При отправке выбрасывается исключение типа Swift_TransportException. Однако, вышеприведенный код его не ловит, что делать?

Лог Apache2 (error.log):

[Fri Mar 22 12:23:48 2013] [error] [client 127.0.0.1] PHP Fatal error: Uncaught exception 'Swift_TransportException' with message 'Connection could not be established with host localhost [Connection refused #111]' in /PATHTOSRC/vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php:266nStack trace:n#0 /PATHTOSRC/vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php(66): Swift_Transport_StreamBuffer->_establishSocketConnection()n#1 /PATHTOSRC/vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/AbstractSmtpTransport.php(117): Swift_Transport_StreamBuffer->initialize(Array)n#2 /PATHTOSRC/vendor/swiftmailer/swiftmailer/lib/classes/Swift/MemorySpool.php(73): Swift_Transport_AbstractSmtpTransport->start()n#3 /PATHTOSRC/vendor/silex/silex/src/Silex/Provider/SwiftmailerServiceProvid in /PATHTOSRC/vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php on line 266

1 ответов


Нашел ошибку - надо было включить вывод всех ошибок:

ini_set(display_errors, "on");
error_reporting(E_ALL);
и все стало ловиться)

а так?

catch (\Swift_TransportException $e) {
    print_r($e->getMessage());
}

Следуя из текста ошибки у вас вылетает из за PHP Fatal error который отловить с помощью catch не получится.

Connection could not be established with host localhost - говорит о том что на localhost либо нет этого сервера либо он не запущен либо вообще хост неправильно указан. Надо решать именно эту проблему.