0

0

laravel怎么实现用户操作日志记录_laravel用户操作日志记录实现

尼克

尼克

发布时间:2025-10-17 10:00:01

|

650人浏览过

|

来源于php中文网

原创

通过模型观察者、事件监听器和中间件三种方式实现Laravel操作日志记录,首先创建UserActionLog模型并迁移数据表,利用UserActivityObserver监听用户模型的增删改行为并写入日志;其次定义UserPerformedAction事件与LogUserAction监听器,支持异步队列处理复杂场景下的日志记录;最后通过LogUserActivity中间件拦截请求,记录用户访问路径、IP、操作时间等信息,并结合手动调用确保关键操作可审计,三者结合实现全面、灵活、可维护的日志系统。

laravel怎么实现用户操作日志记录_laravel用户操作日志记录实现

如果您希望在 Laravel 应用中记录用户对系统资源的修改行为,例如创建、更新或删除操作,可以通过事件监听与模型观察者机制实现自动化日志收集。这种机制能够帮助开发者追踪用户行为,便于后期审计和问题排查。

本文运行环境:MacBook Pro,macOS Sonoma

一、使用模型观察者记录操作日志

模型观察者允许您将 Eloquent 模型的事件处理逻辑分离到独立的类中,使代码更清晰且易于维护。通过监听模型的 created、updated、deleted 等事件,可以捕获用户的具体操作并写入日志表。

1、执行 Artisan 命令生成日志模型和迁移文件:
php artisan make:model UserActionLog -m

2、编辑生成的迁移文件,在 up 方法中定义日志字段:

user_id、action_type、model_name、record_id、changes、ip_address、user_agent 是关键字段,应包含在迁移中。

3、运行迁移命令创建数据表:
php artisan migrate

4、创建观察者类:
php artisan make:observer UserActivityObserver --model=User

5、在生成的观察者类中实现 created、updated、deleted 方法,向 UserActionLog 写入相应记录。

6、在服务提供者如 AppServiceProvider 的 boot 方法中注册观察者:
User::observe(UserActivityObserver::class);

二、利用 Laravel 事件与监听器机制

Laravel 提供了强大的事件广播系统,您可以自定义事件并在监听器中处理日志写入逻辑。这种方式更适合复杂业务场景,支持解耦和异步处理。

1、定义一个事件类用于触发操作日志记录:
php artisan make:event UserPerformedAction

2、在事件类构造函数中接收用户、操作类型、目标模型及变更数据等参数。

专卖店通用管理系统
专卖店通用管理系统

专卖店通用管理系统☆操作方便实用,通用性强,可适用于各类专卖店管理☆实现了货物的库存警告提示,会根据货物的库存情况,到达了设定的库存警界的话就会自动警告提示通知及时补货☆实现分类日期统计功能,可以对前一天,前一个星期和本月的销售记录和各自的赢利情况进行分类统计.

下载

3、创建对应的监听器:
php artisan make:listener LogUserAction --queue

4、在监听器的 handle 方法中实例化 UserActionLog 并保存日志信息。

5、在需要记录的地方分发事件:
event(new UserPerformedAction($user, 'update', $model, $changes));

6、为提升性能,可将监听器设置为队列任务,在配置中启用 shouldQueue 属性。

三、通过中间件记录路由访问日志

中间件可用于拦截 HTTP 请求,在请求进入控制器之前或之后执行日志记录操作。适用于记录页面访问、API 调用等行为。

1、创建自定义中间件:
php artisan make:middleware LogUserActivity

2、将中间件注册到 Kernel.php 的 $middlewareGroups 或单独命名使用。

3、在中间件的 handle 方法中获取当前用户(若已登录)、请求路径、请求方法、IP 地址等信息。

4、判断是否需要记录该请求(例如排除心跳检测接口),然后写入 UserActionLog 表。

5、对于敏感操作,可在控制器方法中手动调用日志服务进行精确控制。

6、确保中间件顺序正确,避免因前置认证中间件未执行导致用户信息为空。

相关专题

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

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

2678

2023.09.01

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

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

1659

2023.10.11

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

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

1515

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数据库相关内容,可以阅读本专题下面的文章。

1419

2023.10.23

html怎么上传
html怎么上传

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

1235

2023.11.03

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

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

1488

2023.11.09

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

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

1306

2023.11.13

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

11

2026.01.19

热门下载

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

精品课程

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

共137课时 | 8.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 8.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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