public override int SaveChanges() { var entries = ChangeTracker.Entries().Where(x => x.State != EntityState.Unchanged).GroupBy(x => new { x.State, x.Entity.GetType().Name }).Select(x => new { x.Key.State, x.Key.Name, List = x.ToList() }); JsonSerializerSettings settings = new JsonSerializerSettings { ReferenceLoopHandling = ReferenceLoopHandling.Ignore// 发现循环引用时跳过序列化 }; foreach (var item in entries) { Logger.WriteOperationlog($" Operation {item.State} Date:{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")} Entity:{item.Name} Data:{JsonConvert.SerializeObject(item.List.Select(x => x.Entity).ToList(), settings)}", "Default"); } return base.SaveChanges(); }