laravel数据库切换(实现laravel 插入操作日志到数据库的方法)
类别:编程学习 浏览量:1795
时间:2021-10-08 00:02:25 laravel数据库切换
实现laravel 插入操作日志到数据库的方法1 . 创建一个中间件
执行: php artisan make:middleware OperationLog
2 . 在中间件中编写一个writeLog() 或者直接写在handle里面
|
<?php namespace App\Http\Middleware; use App\User; use Closure; use Illuminate\Support\Facades\Auth; class OperationLog { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure $next * @return mixed */ public function handle( $request , Closure $next ) { $input = $request ->all(); //操作的内容 $path = $request ->path(); //操作的路由 $method = $request ->method(); //操作的方法 $ip = $request ->ip(); //操作的IP $usernum = $request ->usernum; //操作人(要自己获取) self::writeLog( $usernum , $input , $path , $method , $ip ); return $next ( $request ); } public function writeLog( $usernum , $input , $path , $method , $ip ){ $user = User::where( 'usernum' , $usernum )->first(); if ( $user ) { $user_id = $user ->userid; } $log = new \App\Models\OperationLog(); $log ->setAttribute( 'user_id' , $user_id ); $log ->setAttribute( 'path' , $path ); $log ->setAttribute( 'method' , $method ); $log ->setAttribute( 'ip' , $ip ); $log ->setAttribute( 'input' , json_encode( $input , JSON_UNESCAPED_UNICODE)); $log ->save(); } } |
3 .创建一个OperationLog模型(这里我放在Models文件夹下了)
执行 : php artisan make:model Models\OperationLog
|
<?php namespace App\Models; use Illuminate\Database\Eloquent\Model; class OperationLog extends Model { //定义表 protected $table = "operation_log" ; //定义主键 protected $primaryKey = "id" ; } |
4 . 将中间件注册到Kernel.php 文件
|
/** * The application's global HTTP middleware stack. * * 这些中间件是在对应用程序的每次请求中运行的 * * @var array */ protected $middleware = [ ......., ......., ......., \App\Http\Middleware\OperationLog:: class , ]; |
大功告成…
以上这篇实现laravel 插入操作日志到数据库的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持开心学习网。
原文链接:https://blog.csdn.net/qq_26282869/article/details/81808558
您可能感兴趣
- laravel指定管理员(在laravel-admin中列表中禁止某行编辑、删除的方法)
- laravel 开发自定义组件(laravel实现上传图片并在页面显示的例子)
- laravel获取数据(laravel 判断查询数据库返回值的例子)
- laravel自定义使用方法(Laravel使用Queue队列的技巧汇总)
- laravel-admin代码执行流程(解决laravel-admin 自己新建页面里 js 需要刷新一次的问题)
- laravel配置文件动态化(在Laravel 的 Blade 模版中实现定义变量)
- laravel队列是如何触发的(laravel 事件/监听器实例代码)
- laravel查询限制输出设置(laravel 获取某个查询的查询SQL语句方法)
- laravel入门教程零基础(Laravel5.7框架安装与使用学习笔记图文详解)
- laravel获取访问来路的函数(Laravel实现搜索的时候分页并携带参数)
- laravel怎么查询信息过滤(laravel多条件查询方法and,or嵌套查询)
- laravel 后台任务配置(在Laravel中使用GuzzleHttp调用第三方服务的API接口代码)
- laravel事务状态(laravel dingo API返回自定义错误信息的实例)
- laravel队列失败原理(Laravel第三方包报class not found的解决方法)
- laravel定时脚本(laravel实现按时间日期进行分组统计方法示例)
- laravel模型详解(laravel config文件配置全局变量的例子)
- oppo手机的三种录屏方法,你知道有哪些吗(oppo手机的三种录屏方法)
- 吉林神秘传染链跨省 传染源尚未找到,舒兰 封城(吉林神秘传染链跨省)
- 吉林舒兰 封城 聚集性疫情传播链已延至沈阳,有一个细节让人忧心(吉林舒兰封城)
- 1天密接者猛增77人,患者轨迹透露危险信号 吉林市全面封闭管理(1天密接者猛增77人)
- 吉林舒兰 封城 15人确诊 276人隔离,出现跨省传播(吉林舒兰封城)
- 四月新番CP人气榜公布,《剃须》两度上榜,沙优不是女朋友(四月新番CP人气榜公布)
热门推荐
- ros必须在ubuntu安装吗(详解ubuntu20.04下CLion2020.1.3安装配置ROS过程说明)
- 如何重新配置mysql的端口(如何快速修改MySQL用户的host属性)
- 微信小程序企业微信打卡(使用Python实现企业微信的自动打卡功能)
- 使用python爬取网易云音乐(15行Python代码实现网易云热门歌单实例教程)
- tomcat配置远程调试(一次tomcat源码启动控制台中文乱码的调试过程记录)
- vue将弹框抽离成组件(vue3 可拖动的左右面板分割组件实现)
- mysql与oracle体系结构(详解MySQL实时同步到Oracle解决方案)
- php中变量定义规则(php use和include区别总结)
- Request.Url的值有可能会带端口号
- python爬虫模块教程(Python爬虫之UserAgent的使用实例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9