前言:
最近新项目中有一项新的需求,就是对于某些表,如果进行了增删改操作,那么就对这些操作进行日志记录。
概述:
首先,我该项目是基于Laravel 7.0开发。其实该需求说难也不难,相信很多读者一看到日志,那么肯定想到的就是钩子,只要对这些表的操作做些关联的钩子,那么自然增删改操作也有日志了。说到钩子,可能Laravel中大家用得比较多的功能就是中间件,中间件可以作为某个请求前的钩子,也可以作为请求后的钩子。但是,中间件是针对请求的,而这次我们是针对表来做日志的,那么有没有类似中间件的功能呢?其实Laravel作为一个MVC框架,对表的操作,就是对模型的操作,也就是说我们对模型做个钩子功能就能实现需求了。而Laravel也提供两种方式来处理这种情况。第一种方式通过模型事件 (Event) ,第二种方式基于一种更先进的概念:模型观察者 (Observers)。
事件 (Event) :
首先,我们来看看Laravel的官方文档是如何介绍事件的:事件系统
大概总结一下,建立一个事件很简单:
- 在 EventServiceProvider 中你可以添加一个特定的事件监听器,并绑定一个闭包函数
- 在闭包函数中,你不需要接触模型代码就可以添加新的行为
- 绑定操作必须放在类的 boot() 方法中
需要注意的是,Laravel预设计了一些方法提供给使用者对模式的操作。
- creating
- created
- updating
- updated
- saving
- saved
- deleting
- deleted
- restoring
- restored
其实看方法名,都能大概理解到,create、update、save、delete、restore这几个方法不就是模型的操作吗?而比如creating代表的是将要进行,而created代表的是已完成了。因此,我们可以根据自己需求选择方法。
这样看来,模型事件完全就能满足我们需求了&#