打造更好用的 EF 自动审计
打造更好用的 EF 自动审计
Intro
上次基于 EF Core 实现了一个自动审计的功能,详细可以参考 EF Core 数据变更自动审计设计,虽然说多数情况下可以适用,但是因为要显式继承于一个 AuditDbContextBase
或 AuditDbContext
,所以对代码的侵入性比较强,对于已经无法修改的代码或者已经继承于某一个类了,就无法再继承 AuditDBContext
了,就没有办法实现自动审计了,在 WeihanLi.EntityFramework
1.7.0 新版本里引入了 AOP 的设计,结合 AOP 来实现就简单很多了,不再需要对原有的 DbContext
有任何修改就可以轻松实现自动审计了,下面来看如何做
实例演示
服务注册
使用 AddProxyDbContext
代替 AddDbContext
, AddProxyDbContextPool
代替 AddDbContextPool
,会自动注册代理服务,以实现 AOP 拦截
var services = new ServiceCollection();
// 使用内置的扩展注册 DbContext 代理服务
//services.AddProxyDbContext<TestDbContext>(options =>
//{
// options
// .UseLoggerFactory(loggerFactory)
// //.EnableDetailedErrors()
// //.EnableSensitiveDataLogging()
// // .UseInMemoryDatabase("Tests")
// .UseSqlServer(DbConnectionString)
// //.AddInterceptors(new QueryWithNoLockDbCommandInterceptor())
// ;
//});
// 使用内置的扩展注册 DbContextPool 代理服务,只是为了方便使用,只会代理 DbContext
services.AddProxyDbContextPool<TestDbContext>(options =>
{options.UseLoggerFactory(loggerFactory)//.EnableDetailedErrors()//.EnableSensitiveDataLogging()// .UseInMemoryDatabase("Tests").UseSqlServer(DbConnectionString)//.AddInterceptors(new QueryWithNoLockDbCommandInterceptor());
});
// 注册 AOP 服务
services.AddFluentAspects(options =>
{// 配置使用 AuditDbContextInterceptor 拦截 DbContext 的 SaveChanges 和 SaveChangesAsync 方法options.InterceptMethod<DbContext>(m =>m.Name == nameof(DbContext.SaveChanges)|| m.Name == nameof(DbContext.SaveChangesAsync)).With<AuditDbContextInterceptor>();
});
// 注册 serviceLocator(可选,根据自己需要
DependencyResolver.SetDependencyResolver(services);
审计配置
AuditConfig.Configure(builder =>
{builder// 配置操作用户获取方式.WithUserIdProvider(EnvironmentAuditUserIdProvider.Instance.Value)//.WithUnModifiedProperty() // 保存未修改的属性,默认只保存发生修改的属性// 保存更多属性.EnrichWithProperty("MachineName", Environment.MachineName).EnrichWithProperty(nameof(ApplicationHelper.ApplicationName), ApplicationHelper.ApplicationName)// 保存到自定义的存储.WithStore<AuditFileStore>().WithStore<AuditFileStore>("logs0.log")// 忽略指定实体.IgnoreEntity<AuditRecord>()// 忽略指定实体的某个属性.IgnoreProperty<TestEntity>(t => t.CreatedAt)// 忽略所有属性名称为 CreatedAt 的属性.IgnoreProperty("CreatedAt");
});
使用示例
DependencyResolver.TryInvokeService<TestDbContext>(dbContext =>
{dbContext.Database.EnsureDeleted();dbContext.Database.EnsureCreated();var testEntity = new TestEntity(){Extra = new { Name = "Tom" }.ToJson(),CreatedAt = DateTimeOffset.UtcNow,};dbContext.TestEntities.Add(testEntity);dbContext.SaveChanges();testEntity.CreatedAt = DateTimeOffset.Now;testEntity.Extra = new { Name = "Jerry" }.ToJson();dbContext.SaveChanges();dbContext.Remove(testEntity);dbContext.SaveChanges();var testEntity1 = new TestEntity(){Extra = new { Name = "Tom1" }.ToJson(),CreatedAt = DateTimeOffset.UtcNow,};dbContext.TestEntities.Add(testEntity1);var testEntity2 = new TestEntity(){Extra = new { Name = "Tom2" }.ToJson(),CreatedAt = DateTimeOffset.UtcNow,};dbContext.TestEntities.Add(testEntity2);dbContext.SaveChanges();
});
DependencyResolver.TryInvokeService<TestDbContext>(dbContext =>
{dbContext.Remove(new TestEntity(){Id = 2});dbContext.SaveChanges();
});
// disable audit
AuditConfig.DisableAudit();
// enable audit
// AuditConfig.EnableAudit();
审计日志输出结果
More
这样一来就不需要修改原有代码了~~,心情大好,哈哈~
如果应用多有多个 DbContext
有的需要审计,有的不需要审计,则可以在配置的时候指定具体的 DbContext
类型如 TestDbContext
,这样就只会启用 TestDbContext
的自动审计,别的 DbContext
比如 Test2DbContext
就不会自动审计了
Reference
https://github.com/WeihanLi/WeihanLi.EntityFramework/blob/dev/samples/WeihanLi.EntityFramework.Core3_0Sample/Program.cs
https://www.nuget.org/packages/WeihanLi.EntityFramework/
EF Core 数据变更自动审计设计
打造更好用的 EF 自动审计相关推荐
- EF Core 数据变更自动审计设计
EF Core 数据变更自动审计设计 Intro 有的时候我们需要知道每个数据表的变更记录以便做一些数据审计,数据恢复以及数据同步等之类的事情, EF 自带了对象追踪,使得我们可以很方便的做一些审计工 ...
- 听见丨苹果申请自主导航系统专利,自动驾驶汽车梦再近一步 现代打造更聪明、实用汽车AI语音系统
浙江合众新能源宣布获知合出行12.5亿元注资,首款新车将于明年年中上市 昨天下午,浙江合众新能源宣布获知合出行12.5亿元注资并完成控股股东变更.合众新能源成立于2014年,由北京亿华通科技股份有限公 ...
- 打造一个属于自己的应用服务自动监控警报程序
打造一个属于自己的应用服务自动监控警报程序 公司的各项网络应用服务越来越多了,大到:ERP.PDM.数据库服务器等应用服务,小到一台用PC做的文件服务器或者多台打印服务器.并且,更为复杂的是:随着公司 ...
- 携手独角兽企业,微软正在用AI打造更美好的未来
让AI为孩子讲童话故事,让购物变得更加方便快捷,让听力障碍人士可以更自如地生活--这些科技发展带来的恩惠,正在真真切切地改写着我们每个人的生活. 然而许多人可能并不知道的是,在这些看得见的恩惠背后,其 ...
- 端云协同,打造更易用的AI计算平台
内容来源:华为开发者大会2021 HMS Core 6 AI技术论坛,主题演讲<端云协同,HUAWEI HiAI Foundation打造更易用的AI计算平台>. 演讲嘉宾:华为海思AI技 ...
- 华为云弹性云服务器助力打造更安全可靠、灵活高效的云空间
华为云弹性云服务器助力打造更安全可靠.灵活高效的云空间 云服务器大家一定都听说或者了解过,那我们今天来了解一下什么是弹性云服务器,弹性云服务器(Elastic Cloud Server)简而言之,是为 ...
- OMS 3.4.0 发布,打造更安全易用的数据迁移体验
OceanBase 数据迁移工具(OceanBase Migration Service,OMS)是 OceanBase 数据库一站式数据传输和同步的产品.它支持多种关系型数据库(如 Oracle.D ...
- 人大金仓携手深信服打造更高效、更融合一体化平台联合解决方案
近日,人大金仓数据库与深信服超融合平台完成深度优化,表现出性能更优.运行更稳定.数据更安全.双方联合打造更高效.更融合的一体化平台联合解决方案,能更好地满足行业信创升级需求. 随着新一轮信创政策陆续出 ...
- 世纪前线网络质量测试工具 是什么_卓拙科技 | 为全球用户打造更快、更稳定、更安全的的网络环境...
成都IT内推圈成立于2016年,专注成都IT互联网领域的招聘与求职;覆盖精准IT人群10W+,通过内推圈推荐且已入职人数超过5000+,合作公司均系成都知名或靠谱公司.此公众号每天7:30AM准时推送 ...
最新文章
- 独家 | 17篇手把手教技术指南、技术进阶干货大合集
- 2017各银行贷款利息表及P2P平台贷款利率比较
- 如何提高还在用window系统的编码硬效率
- uboot给内核传参的方式——tag
- Win7下如何更改时间日期
- withMisfireHandlingInstruction
- 真希望永远用不到这些代码
- Pycharm 专业版 导入系统pip安装的包
- Qt笔记-解决QObject::startTimer: Timers cannot be started from another thread
- 比dropout更好的方法_比较自己的更好方法
- Intellij IDEA神器常用技巧六-Debug详解
- coalesce函数_什么是SQL Server COALESCE()函数?
- 写这么骚的代码,不怕被揍么?
- Word 2019怎样自定义模板,并将自定义模板设为默认模板
- 关于git代码管理的详细操作流程
- uni-app 背景图片设置
- 【JAVA】xml文件的读取
- AxureRP和Markman新手入门心得
- android 9.0 10.0 去掉音量键+Power键组合键的屏幕截图功能
- 如何在知网下载硕士、博士论文PDF?
热门文章
- LeetCode: 14. Longest Common Prefix
- c/c++与java------之JNI学习(一)
- 10进制转化为16进制以内的转化
- decimal,float和double的区别
- 如何在Windows 10上跳过回收站以删除文件
- Ubuntu 12.10中的8个新功能,Quantal Quetzal
- windows删除桌面ie_从Windows 8“开始”屏幕启动IE的桌面版本
- 搭建spring boot环境并测试一个controller
- php优化-》常用到的部分优化
- Sonnedix收购意大利11.2MW光伏电站产品组合