javascript - (错误)日志记录的最佳实践

标签 javascript php error-handling error-logging

所以我正在尝试为我的网络应用程序创建日志记录。它的前端使用 HTML/CSS/JS 编写,后端使用 PHP 编写,使用 MariaDB 数据库。我正在尝试在所有代码中创建错误/警告等日志记录。这意味着,不仅适用于 PHP 代码,还适用于 JS(也许将来甚至更多语言)。 PHP 和 JS 中的大部分处理都已经完成,并且 JS 错误通过 AJAX 发送到服务器。现在我遇到的问题是,将这些错误保存到数据库的最佳方法是什么。

现在我的数据库中有 1 个表出现错误,如下所示:

id         BIGINT  (10)  -- Primary Key
message    TEXT          -- The error message
type       VARCHAR (255) -- warning/error/notice/deprication etc...
origin     VARCHAR (255) -- JS/PHP etc...
account_id BIGINT  (10)  -- Foreign Key to an account table

c_dt DATETIME            -- Creation datetime
u_dt DATETIME            -- Update datetime
d_dt DATETIME            -- Delete datetime (implementation of soft delete)

注意:这与审核日志不同,审核日志是在不同的表中实现的。

澄清; message 只是一个格式化字符串,是从引发的事件创建的。该字符串的一些实际示例是:

  • phpHandler 捕获以下事件:2:mysqli::real_escape_string() 期望参数 1 为字符串,给定数组。文件:\path\to\the\databaseManager.php,行:206。
  • 引用错误:myfunc 未定义。文件:myFile.js 行:22 列:70
  • phpHandler 捕获以下事件:8:未定义索引:例程。文件:\path\to\the\Entrance.php,行:7。

但是,我无法(轻松)从字符串中获取行号等。或者按文件名分组并查看哪些文件造成的问题最多。当然,添加文件名或行号等列可以解决此问题。但并非所有语言在发生错误时都会给出相同的信息。例如,JS 中的错误对象有列号、文件名、行号、浏览器名称等......但 PHP 的所有这些信息要少得多。而如果我将来想实现更多的(后端)语言,信息上只会有更多的差异。

所以我的问题是,将错误保存到数据库的最佳实践是什么?每个(相似组)语言都有自己的表并包含各自的信息? 1 有很多列的表?只保存基本信息,例如文件/行号严重性?

此外,我可能忽略了上述解决方案的一些优点和缺点?

最佳答案

我建议在数据库中使用 JSON 类型字段。 For more information about JSON type

您可以记录有关警告、错误等的详细信息。只需小心将可查询字段存储为表中的字段即可。

关于javascript - (错误)日志记录的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46754412/

相关文章:

javascript - 如何修复GTM中的 "This language feature is only supported for ECMASCRIPT6 mode"?

php - Codeigniter (CSRF) jQuery ajax 问题

php - 带有 PHP 的 MySQL - LIKE 无法正常工作

php - 按国家/地区获取 Twitter 主题标签

asp.net - ASP.NET MVC 4自定义错误 View 问题

c++ - 在非 void 函数中我不想返回任何内容

python - 在Tkinter中设置错误处理循环

javascript - 在 PHP 中单击复选框时更新状态

javascript - 字符串结尾正则表达式匹配太慢

javascript - 如何从控制台访问 extjs Controller