Задать вопрос
@Misha_Angelov

Как логировать ошибки php?

Нужна помощь с выводом ошибок.
У меня есть бот в телеграмме и мой файл bot.php напичкан разными функциями и классами. На него и приходят webhook-и от Телеграмм. Соответственно код выполняется без моего участия. Как мне записывать все ошибки в какой-то файл и потом выводить на другой странице?
Думал о try catch в котором был следующий код:
//file bot.php
try{
#code...
} catch (\Exception $e) {
    save_error($e);
} catch (\Throwable $th) {
    save_error($th);
}

Сама функция save_error:
function save_error($e)
{
    $class = get_class($e);
    $mes = $e->getMessage();
    $code = $e->getCode();
    $file = $e->getFile();
    $line = $e->getLine();
    $trace = $e->getTrace();
    $time = date('m-d | H:i:s');
    $text =
        "class: $class<br>".
        "time: $time<br>".
        "mes: $mes<br>".
        "code: $code<br>".
        "file: $file<br>".
        "line: $line<br>".
        print_r($trace, true);
    file_put_contents(
        'path',
        $text
    );
}
  • Вопрос задан
  • 78 просмотров
Подписаться 1 Простой 1 комментарий
Решения вопроса 1
Пригласить эксперта
Ответы на вопрос 1
FanatPHP
@FanatPHP
Чебуратор тега РНР
РНР уже всё умеет из коробки.
Чтобы просто залогировать ошибку, не нужно никаких библиотек и хендлеров.
Функция save_error - это абсолютно бессмысленные телодвижения, которые повторяют то что уже есть в РНР

Чтобы ошибки логировались, надо - сюрприз! - написать в настройках одну строчку

log_errors=1

всё, больше ничего не надо
ошибки сами будут записывться в лог
без траев, кетчей, шатдаунов и прочей ерунды

И кстати
} catch (\Exception $e) {
    save_error($e);
} catch (\Throwable $th) {
    save_error($th);
}
- это отдельная бессмыслица.
Throwable уже включает в себя Exception
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы