Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Не понтятно как работать с ErrorException
Форумы портала PHP.SU » » Вопросы новичков » Не понтятно как работать с ErrorException

Страниц (1): [1]
 

1. shum0531 - 12 Апреля, 2019 - 21:21:50 - перейти к сообщению
Объясните как работать с ErrorException, а конкретно, второй ($code) и третий ($severity) параметр конструктора, не понятна разница
из примера
PHP:
скопировать код в буфер обмена
  1. function fn_error_handler($severity, $message, $file, $line) {
  2.     if (!(error_reporting() & $severity)) {
  3.         // Этот код ошибки не входит в error_reporting
  4.         return;
  5.     }
  6.     throw new ErrorException($message, 0, $severity, $file, $line);
  7. }
  8. set_error_handler("fn_error_handler");
Почему "0"? Ведь если мы будем ловить исключения, то:
PHP:
скопировать код в буфер обмена
  1. function fn_exception_handler($e) {
  2.     // то: $e->getCode() == 0, как раз то самы ноль, котовый мы передали вторым параметром;
  3. }
  4. set_exception_handler("fn_exception_handler"]);
Зачем тогда третий параметр?
2. Мелкий - 12 Апреля, 2019 - 21:49:11 - перейти к сообщению
code присутствует т.к. он присутствует в классе Exception выше в иерархии наследования, а конструктор предполагается единственным способом задания этого параметра.
Можете использовать как пожелаете или игнорировать его.

severity добавлен непосредственно в ErrorException и предполагается что будет использован для передачи E_* констант. Его некорректно называть кодом ошибки, это уровень предупреждения. Поэтому это две разные штуки. severity уровень пойманного ErrorException можете получить методом getSeverity
3. qtk - 19 Апреля, 2019 - 12:35:35 - перейти к сообщению
PHP:
скопировать код в буфер обмена
  1.     function ($errno, $errstr) {
  2.         throw new \ErrorException($errstr);
  3.     },
  4.     E_WARNING
  5. );
  6.  
  7. set_exception_handler(function (Throwable $t) {
  8.     $logFile = BASEDIR . '/log/' .  basename($_SERVER['PHP_SELF'], '.php') . '.txt';
  9.     $logMsg = "[" . date('D d M Y H:i:s') . "] \n" . $t . "\n\n";
  10.     file_put_contents($logFile, $logMsg, FILE_APPEND);
  11.     echo $t;
  12. });

 

Powered by ExBB FM 1.0 RC1