0

0

PHP增删改查怎么记录操作日志_php日志记录代码【实现】

蓮花仙者

蓮花仙者

发布时间:2025-12-22 22:05:36

|

776人浏览过

|

来源于php中文网

原创

php增删改查操作日志记录有五种方法:一、pdo预处理封装日志写入;二、mysql触发器同步写入日志表;三、中间件或基类统一拦截;四、monolog库结构化日志输出;五、sql注释嵌入客户端标识。

php增删改查怎么记录操作日志_php日志记录代码【实现】

当在PHP应用中执行增删改查操作时,记录每次数据库操作的详细信息有助于追踪数据变更、排查问题和满足审计要求。以下是实现PHP增删改查操作日志记录的具体方法:

一、使用PDO预处理语句封装日志写入

该方法在执行SQL前统一捕获操作类型、SQL语句、参数及执行结果,并将日志写入文件或数据库。所有数据库操作通过同一入口函数调用,便于集中控制日志逻辑。

1、定义日志记录函数logDatabaseOperation(),接收操作类型(INSERT/UPDATE/DELETE/SELECT)、原始SQL、绑定参数数组、执行耗时和是否成功标志。

2、在函数内部拼接日志内容,格式为:[时间] [操作类型] [SQL摘要] [参数] [状态] [耗时ms]。

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

3、使用file_put_contents()以FILE_APPEND模式写入日志文件,例如"log/db_operation_".date('Y-m-d').".log"。

4、在PDO执行前调用logDatabaseOperation()记录待执行信息,在execute()后再次调用并传入实际执行结果与耗时。

二、基于MySQL触发器同步写入日志表

该方法不依赖PHP代码逻辑,直接在数据库层捕获DML变更,确保即使绕过PHP接口的直接SQL操作也能被记录,提升日志完整性与可靠性。

1、创建日志表operation_log,包含字段:id、table_name、operation_type(ENUM('INSERT','UPDATE','DELETE'))、old_data(JSON)、new_data(JSON)、operator_ip(VARCHAR)、created_at。

2、为需监控的数据表(如user、order)分别创建AFTER INSERT、AFTER UPDATE、AFTER DELETE触发器。

3、在INSERT触发器中,将NEW.*写入new_data字段,并置old_data为NULL;在UPDATE触发器中,将OLD.*和NEW.*分别序列化为JSON存入old_data与new_data;在DELETE触发器中,将OLD.*写入old_data,new_data为NULL。

4、通过USER()或自定义会话变量获取当前操作用户,结合$_SERVER['REMOTE_ADDR'](需PHP层传入临时变量)补充operator_ip字段。

三、通过中间件或基类统一拦截DB操作

适用于使用自定义数据库访问类或ORM框架的项目,通过继承或装饰器方式将日志逻辑注入到query()、insert()、update()、delete()等公共方法中,避免重复编码

1、定义抽象基类DatabaseManager,其所有CRUD方法均先调用recordLog()再执行实际SQL。

Unscreen
Unscreen

AI智能视频背景移除工具

下载

2、recordLog()方法根据调用获取当前方法名,映射为操作类型:insert对应INSERT,update对应UPDATE,delete对应DELETE,select对应SELECT

3、从调用参数中提取表名、WHERE条件片段(用于SELECT/UPDATE/DELETE摘要)、SET或VALUES值(用于INSERT/UPDATE摘要)。

4、构造结构化日志数组,包含timestamp、action、table、sql_summary、params、ip、user_id(若已登录),再序列化为JSON写入日志流。

四、利用Monolog库集成结构化日志输出

该方法借助成熟日志组件Monolog,支持多通道输出(文件、Syslog、Elasticsearch等),并可按操作类型设置不同日志级别,便于后续检索与分析。

1、通过Composer安装monolog/monolog,实例化Logger对象并添加StreamHandler指向CRUD专用日志文件。

2、为每种操作类型定义独立日志上下文,例如insert操作使用context=['type'=>'insert','table'=>'user','data'=>$data]。

3、在执行insert()方法时调用$logger->info("Record created", $context);update()调用$logger->notice("Record updated", $context);delete()调用$logger->warning("Record deleted", $context)。

4、配置Monolog的JsonFormatter,使每条日志以标准JSON格式输出,确保字段包含level、message、context、datetime,便于ELK栈采集解析。

五、在SQL语句中嵌入客户端标识与操作标签

该方法通过修改原始SQL语句,在注释中注入可识别的操作元信息,使数据库慢查询日志或通用审计日志能反向定位PHP调用来源,适合已有系统低侵入改造。

1、在PHP构造SQL时,于语句开头插入形如/* PHP-INSERT-user-v1.2 uid:1001 */的注释块。

2、注释中固定包含三段信息:执行语言与操作(PHP-INSERT/PHP-UPDATE等)、业务表名与版本、关键业务标识(如uid、order_id、session_id)。

3、确保PDO或MySQLi启用MYSQLI_OPT_CONNECT_TIMEOUT与MYSQLI_REPORT_STRICT,使SQL注释不影响语法解析。

4、配置MySQL的general_log或slow_query_log,开启log_output=TABLE并将日志写入mysql.general_log表,后续可按注释内容筛选PHP相关操作

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

161

2023.12.25

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1683

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 847人学习

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

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