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。

易标AI
易标AI

告别低效手工,迎接AI标书新时代!3分钟智能生成,行业唯一具备查重功能,自动避雷废标项

下载

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相关操作

相关专题

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

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

2541

2023.09.01

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

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

1608

2023.10.11

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

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

1500

2023.10.11

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

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

952

2023.10.23

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

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

1416

2023.10.23

html怎么上传
html怎么上传

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

1234

2023.11.03

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

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

1446

2023.11.09

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

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

1306

2023.11.13

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

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

精品课程

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

共48课时 | 1.8万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 793人学习

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

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