Composer怎么安装Laravel Auditing_Composer如何引入owen-it/laravel-auditing自动记录模型数据变更日志【教程】

直接用 Composer 安装 owen-it/laravel-auditing:composer require owen-it/laravel-auditing;注意包名拼写准确,安装后自动注册服务提供者,需发布迁移并运行 php artisan migrate 创建 audits 表,模型启用审计需 use Auditable trait 且实现 AuditableContract 接口。

composer怎么安装laravel auditing_composer如何引入owen-it/laravel-auditing自动记录模型数据变更日志【教程】

直接用 Composer 安装 owen-it/laravel-auditing

它不是 Laravel 官方包,但维护活跃、Laravel 9/10 兼容良好,安装就是一条命令:composer require owen-it/laravel-auditing。注意别拼错包名——owen-it/laravel-auditing 中的 owen-it 是作者 GitHub 组织名,不是 owenit 或 owen,拼错会报 Package not found。

安装后自动注册服务提供者(Laravel 5.5+ 支持自动发现),无需手动加到 config/app.php;但如果你用的是 Laravel 5.4 或禁用了自动发现,得手动在 providers 数组里加一行:OwenIt\Auditing\AuditingServiceProvider::class。

发布迁移文件并运行 migrate

审计日志要存进数据库,必须先生成并执行迁移。执行:php artisan vendor:publish --provider="OwenIt\Auditing\AuditingServiceProvider" --tag="migrations"。这会把 create_audits_table.php 迁移文件复制到 database/migrations/ 目录下。

常见错误:没运行这步就直接 php artisan migrate,结果报错 Base table or view not found: 1146 Table 'xxx.audits' doesn't exist。迁移文件生成后,再跑一次 php artisan migrate 就行。

如果项目已上线,别直接删库重迁——audits 表可独立存在,不影响主业务表

默认迁移使用 bigIncrements,适合高并发场景;如确定数据量极小,可手动改成 increments 减少索引体积

表名固定为 audits,不建议改;若真要改,需同时在 config/audit.php 里调整 table 配置项

给模型开启审计功能

不是所有模型都要审计,只在需要记录变更的模型里加 Auditable trait 和接口即可。例如:use OwenIt\Auditing\Contracts\Auditable as AuditableContract;

use OwenIt\Auditing\Auditable;

class User extends Model implements AuditableContract

{

    use Auditable;

}

关键点:

必须实现 AuditableContract 接口,否则运行时会报 Class name must be a valid object or a string 类错误

Auditable trait 默认监听 created、updated、deleted、restored 四个事件;想关掉某个(比如不想记 soft-delete 的 deleted),在模型里设:protected $auditInclude = ['name', 'email']; 或 protected $auditExclude = ['password'];

如果模型用的是自定义主键(非 id),记得设置:protected $auditInclude = ['your_primary_key']; 并确保该字段被包含在审计字段中,否则日志里 auditable_id 可能为空

审计日志查不到?检查配置和软删除行为

最常遇到的情况是:改了数据,但 audits 表里没新记录。优先排查这三处:

whppwxzx.watchpg.com

xappwxzx.watchpg.com

syppwxzx.watchpg.com

dgppwxzx.watchpg.com

tjppwxzx.watchpg.com

csppwxzx.watchpg.com

cqppwxzx.watchpg.com

fsppwxzx.watchpg.com

hzppwxzx.watchpg.com

njppwxzx.watchpg.com

suppwxzx.watchpg.com

wxppwxzx.watchpg.com

bj8wxpp.watchpg.com

cd10wxpp.watchpg.com

gz11wxpp.watchpg.com

sz12wxpp.watchpg.com

zz13wxpp.watchpg.com

heb14wxpp.watchpg.com

wh15wxpp.watchpg.com

xa16wxpp.watchpg.com

qd17wxpp.watchpg.com

sy18wxpp.watchpg.com

dg19wxpp.watchpg.com

tj20wxpp.watchpg.com

cs21wxpp.watchpg.com

cq22wxpp.watchpg.com

fs23wxpp.watchpg.com

hz24wxpp.watchpg.com

nj25wxpp.watchpg.com

su26wxpp.watchpg.com

vconwx.watchpg.com

8wxvcon.watchpg.com

bjvconwx.watchpg.com

shvconwx.watchpg.com

cdvconwx.watchpg.com

gzvconwx.watchpg.com

szvconwx.watchpg.com

zzvconwx.watchpg.com

hebvconwx.watchpg.com

whvconwx.watchpg.com

xavconwx.watchpg.com

qdvconwx.watchpg.com

syvconwx.watchpg.com

dgvconwx.watchpg.com

tjvconwx.watchpg.com

csvconwx.watchpg.com

cqvconwx.watchpg.com

模型是否真的用了 Auditable trait 且实现了接口——漏一个就完全不触发

是否启用了软删除(SoftDeletes)但没在模型里加 use SoftDeletes;?此时 delete() 实际是 update 操作,而默认审计不监听 updated 对 soft-deleted 记录的变更,需显式开启:protected $auditInclude = ['deleted_at'];

配置文件 config/audit.php 是否被意外修改?尤其 enabled 设为 false,或 implementation 指向了错误类——首次发布配置后,Laravel 不会自动覆盖已有文件,改配置得手动确认

审计本身不阻塞主流程,但大量高频更新模型时,每条变更写一次 audits 表可能拖慢响应;如只需关键操作留痕,建议用 $model->auditCustom('user_profile_updated', [...]) 手动触发,比全自动更可控。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • """1.个性化消息: 将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,如“Hello ...
    她即我命阅读 5,788评论 0 6
  • 1、expected an indented block 冒号后面是要写上一定的内容的(新手容易遗忘这一点); 缩...
    庵下桃花仙阅读 1,149评论 1 2
  • 一、工具箱(多种工具共用一个快捷键的可同时按【Shift】加此快捷键选取)矩形、椭圆选框工具 【M】移动工具 【V...
    墨雅丫阅读 1,800评论 0 0
  • 跟随樊老师和伙伴们一起学习心理知识提升自已,已经有三个月有余了,这一段时间因为天气的原因休课,顺便整理一下之前学习...
    学习思考行动阅读 1,183评论 0 2
  • 一脸愤怒的她躺在了床上,好几次甩开了他抱过来的双手,到最后还坚决的翻了个身,只留给他一个冷漠的背影。 多次尝试抱她...
    海边的蓝兔子阅读 1,081评论 1 4

友情链接更多精彩内容