打造更好用的 EF 自动审计

Intro

上次基于 EF Core 实现了一个自动审计的功能,详细可以参考 EF Core 数据变更自动审计设计,虽然说多数情况下可以适用,但是因为要显式继承于一个 AuditDbContextBaseAuditDbContext,所以对代码的侵入性比较强,对于已经无法修改的代码或者已经继承于某一个类了,就无法再继承 AuditDBContext 了,就没有办法实现自动审计了,在 WeihanLi.EntityFramework 1.7.0 新版本里引入了 AOP 的设计,结合 AOP 来实现就简单很多了,不再需要对原有的 DbContext 有任何修改就可以轻松实现自动审计了,下面来看如何做

实例演示

服务注册

使用 AddProxyDbContext 代替 AddDbContextAddProxyDbContextPool 代替 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 自动审计相关推荐

  1. EF Core 数据变更自动审计设计

    EF Core 数据变更自动审计设计 Intro 有的时候我们需要知道每个数据表的变更记录以便做一些数据审计,数据恢复以及数据同步等之类的事情, EF 自带了对象追踪,使得我们可以很方便的做一些审计工 ...

  2. 听见丨苹果申请自主导航系统专利,自动驾驶汽车梦再近一步 现代打造更聪明、实用汽车AI语音系统

    浙江合众新能源宣布获知合出行12.5亿元注资,首款新车将于明年年中上市 昨天下午,浙江合众新能源宣布获知合出行12.5亿元注资并完成控股股东变更.合众新能源成立于2014年,由北京亿华通科技股份有限公 ...

  3. 打造一个属于自己的应用服务自动监控警报程序

    打造一个属于自己的应用服务自动监控警报程序 公司的各项网络应用服务越来越多了,大到:ERP.PDM.数据库服务器等应用服务,小到一台用PC做的文件服务器或者多台打印服务器.并且,更为复杂的是:随着公司 ...

  4. 携手独角兽企业,微软正在用AI打造更美好的未来

    让AI为孩子讲童话故事,让购物变得更加方便快捷,让听力障碍人士可以更自如地生活--这些科技发展带来的恩惠,正在真真切切地改写着我们每个人的生活. 然而许多人可能并不知道的是,在这些看得见的恩惠背后,其 ...

  5. 端云协同,打造更易用的AI计算平台

    内容来源:华为开发者大会2021 HMS Core 6 AI技术论坛,主题演讲<端云协同,HUAWEI HiAI Foundation打造更易用的AI计算平台>. 演讲嘉宾:华为海思AI技 ...

  6. 华为云弹性云服务器助力打造更安全可靠、灵活高效的云空间

    华为云弹性云服务器助力打造更安全可靠.灵活高效的云空间 云服务器大家一定都听说或者了解过,那我们今天来了解一下什么是弹性云服务器,弹性云服务器(Elastic Cloud Server)简而言之,是为 ...

  7. OMS 3.4.0 发布,打造更安全易用的数据迁移体验

    OceanBase 数据迁移工具(OceanBase Migration Service,OMS)是 OceanBase 数据库一站式数据传输和同步的产品.它支持多种关系型数据库(如 Oracle.D ...

  8. 人大金仓携手深信服打造更高效、更融合一体化平台联合解决方案

    近日,人大金仓数据库与深信服超融合平台完成深度优化,表现出性能更优.运行更稳定.数据更安全.双方联合打造更高效.更融合的一体化平台联合解决方案,能更好地满足行业信创升级需求. 随着新一轮信创政策陆续出 ...

  9. 世纪前线网络质量测试工具 是什么_卓拙科技 | 为全球用户打造更快、更稳定、更安全的的网络环境...

    成都IT内推圈成立于2016年,专注成都IT互联网领域的招聘与求职;覆盖精准IT人群10W+,通过内推圈推荐且已入职人数超过5000+,合作公司均系成都知名或靠谱公司.此公众号每天7:30AM准时推送 ...

最新文章

  1. 独家 | 17篇手把手教技术指南、技术进阶干货大合集
  2. 2017各银行贷款利息表及P2P平台贷款利率比较
  3. 如何提高还在用window系统的编码硬效率
  4. uboot给内核传参的方式——tag
  5. Win7下如何更改时间日期
  6. withMisfireHandlingInstruction
  7. 真希望永远用不到这些代码
  8. Pycharm 专业版 导入系统pip安装的包
  9. Qt笔记-解决QObject::startTimer: Timers cannot be started from another thread
  10. 比dropout更好的方法_比较自己的更好方法
  11. Intellij IDEA神器常用技巧六-Debug详解
  12. coalesce函数_什么是SQL Server COALESCE()函数?
  13. 写这么骚的代码,不怕被揍么?
  14. Word 2019怎样自定义模板,并将自定义模板设为默认模板
  15. 关于git代码管理的详细操作流程
  16. uni-app 背景图片设置
  17. 【JAVA】xml文件的读取
  18. AxureRP和Markman新手入门心得
  19. android 9.0 10.0 去掉音量键+Power键组合键的屏幕截图功能
  20. 如何在知网下载硕士、博士论文PDF?

热门文章

  1. LeetCode: 14. Longest Common Prefix
  2. c/c++与java------之JNI学习(一)
  3. 10进制转化为16进制以内的转化
  4. decimal,float和double的区别
  5. 如何在Windows 10上跳过回收站以删除文件
  6. Ubuntu 12.10中的8个新功能,Quantal Quetzal
  7. windows删除桌面ie_从Windows 8“开始”屏幕启动IE的桌面版本
  8. 搭建spring boot环境并测试一个controller
  9. php优化-》常用到的部分优化
  10. Sonnedix收购意大利11.2MW光伏电站产品组合