Laravel 执行操作日志记录

在开发过程中,尤其是内部管理(CRM)、SaaS系统,经常性的会需要对每一步操作进行记录,尤其是修改过的内容,更需要完整性的展示出来,那么操作日志就必不可少。

首先,要获取到对应表的字段名称,在根据前端传来的值进行查找,将查找出来的数据进行比对

use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Schema;


/**
* @param  $request  传的值
* @param  $table    表名称
* @param  $id       要修改的数据
*/
public static function logDesc($request, $table, $id) {
        $fieldName = Schema::getColumnListing($table);   // 获取对应表的字段名
        $input = $request->only($fieldName);
        $value = array_values($input);  // 获取value,用作对比
        $field = array_keys($input);    // 获取键,查找字段

        // 查找对应表中数据
        $data = DB::table($table)->where('id', $request->id)->get($field)->toArray();
        $data = array_values(json_decode(json_encode($data[0]),true));

        // $a 是传值的参数  $b 是表里的参数  获取不一致的内容
        $result = array_map(function($a, $b){
            // 假设有数组的参数,转换展示
            if (is_array($a)) {
                $a = implode('、', $a);
                $b = implode('、', json_decode($b, true));
            }
            if ($a != $b) {
                return array($a, $b);
            }
        }, $value, $data);

        // 将修改过的内容记录
        $content = [];
        foreach ($result as $v) {
            if (!$v) {
                continue;
            }
            $content[] = $v[1] .' 修改为 ' . $v[0];
        }
        $content = implode(';', $content);
        return $content;
    }

仅是我个人浅见,如有更好意见,希望能够交流一番

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值