0

0

php编写日志记录系统的方法_php编写错误追踪的实现技巧

蓮花仙者

蓮花仙者

发布时间:2025-10-27 15:51:02

|

834人浏览过

|

来源于php中文网

原创

可通过文件、异常处理、Monolog库、数据库和日志级别分类实现PHP日志系统:先创建writeLog()函数将格式化信息写入安全路径的log.txt;再用set_exception_handler和set_error_handler捕获未处理异常与错误,转为ErrorException并记录;接着通过Composer安装Monolog,配置Logger和StreamHandler输出多目标日志;然后设计日志表结构,使用PDO将日志存入数据库,并设置清理策略防止膨胀;最后定义日志级别常量,按环境阈值控制输出,开发时启用debug,生产仅记录warning以上。

php编写日志记录系统的方法_php编写错误追踪的实现技巧

如果您在开发PHP应用时需要对程序运行过程中的信息或错误进行追踪,可以通过构建日志记录系统来保存关键操作和异常信息。以下是实现该功能的具体方法。

本文运行环境:Dell XPS 13,Ubuntu 24.04

一、使用文件方式记录日志

通过将日志信息写入指定的文本文件,可以实现简单高效的日志存储。这种方式无需额外服务支持,适合中小型项目。

1、创建一个专门用于写入日志的函数,例如 writeLog(),接收消息内容和日志级别作为参数。

立即学习PHP免费学习笔记(深入)”;

2、在函数内部使用 file_put_contents() 函数将格式化后的时间、级别和消息写入 log.txt 文件中。

3、设置文件路径为项目外目录或受保护目录,防止被外部访问,提升安全性。

4、每次发生关键事件或捕获异常时调用此函数,确保信息持久化。

二、利用内置异常处理机制追踪错误

PHP 提供了 set_exception_handler 和 set_error_handler 函数,可用于捕获未被捕获的异常和传统错误。

1、定义一个异常处理函数,接收异常对象作为参数,并从中提取文件名、行号和错误信息。

2、调用 set_exception_handler() 注册该函数,使其成为全局异常处理器

3、对于非致命错误(如警告、通知),使用 set_error_handler() 捕获并转换为 ErrorException 抛出,以便统一处理。

4、在处理器中调用日志写入函数,将错误详情按时间顺序记录到文件中。

三、集成 Monolog 类库实现专业日志管理

Monolog 是 PHP 社区广泛使用的日志库,支持多种处理器和格式化器,可灵活输出到文件、数据库或远程服务器。

1、通过 Composer 安装 Monolog:composer require monolog/monolog

Quinvio AI
Quinvio AI

AI辅助下快速创建视频,虚拟代言人

下载

2、实例化 Logger 对象,并为其添加 StreamHandler,指定日志输出路径。

3、根据不同的场景使用 debug、info、error 等方法记录对应级别的日志信息。

4、配置多个处理器,例如同时写入本地文件和发送至 syslog,增强监控能力。

四、将日志信息存入数据库

将日志数据存储在数据库中便于查询、筛选和分析,适用于需要长期归档和检索的应用场景。

1、设计一张日志表,包含字段如 id、level、message、file、line、created_at 等。

2、在日志写入函数中建立 PDO 连接,准备插入语句,绑定各项参数。

3、执行插入操作并将结果记录状态返回,失败时可回退到文件备份机制。

4、定期清理过期日志数据,避免数据库膨胀影响性能。

五、按级别分类日志输出

通过区分日志级别(如 debug、info、warning、error),可以更精准地控制输出内容和排查问题。

1、定义常量或枚举表示不同级别,例如 LOG_DEBUG = 100,LOG_ERROR = 400。

2、在写入前判断当前环境设定的日志阈值,低于该级别的日志不予记录。

3、在每条日志前标注级别标识,方便后期快速识别严重程度。

4、开发环境中启用 debug 级别,生产环境仅记录 warning 及以上级别。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2788

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1685

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1547

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1016

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1484

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1255

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1569

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1307

2023.11.13

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号