Sparkdo.Auditing
1.0.1
.NET 10.0
This package targets .NET 10.0. The package is compatible with this framework or higher.
.NET Standard 2.0
This package targets .NET Standard 2.0. The package is compatible with this framework or higher.
There is a newer prerelease version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package Sparkdo.Auditing --version 1.0.1
NuGet\Install-Package Sparkdo.Auditing -Version 1.0.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Sparkdo.Auditing" Version="1.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Sparkdo.Auditing" Version="1.0.1" />
<PackageReference Include="Sparkdo.Auditing" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Sparkdo.Auditing --version 1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Sparkdo.Auditing, 1.0.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Sparkdo.Auditing@1.0.1
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Sparkdo.Auditing&version=1.0.1
#tool nuget:?package=Sparkdo.Auditing&version=1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Sparkdo.Auditing
Sparkdo 审计库,提供方法调用和实体变更的自动审计日志记录功能。
功能特性
- 方法调用审计:自动记录服务方法的调用信息
- 实体变更审计:跟踪实体的创建、更新和删除操作
- 审计贡献者模式:支持自定义审计信息扩展
- 多租户支持:记录租户相关信息
- 用户信息跟踪:记录当前用户信息
- 异常审计:记录方法执行中的异常信息
- 审计存储扩展:支持自定义审计日志存储方式
- 与 Sparkdo 框架无缝集成
安装
<PackageReference Include="Sparkdo.Auditing" Version="x.x.x" />
核心组件
AuditingInterceptor
审计拦截器,用于拦截方法调用并记录审计信息:
- 自动记录方法执行时间
- 记录方法参数信息
- 捕获并记录异常信息
DefaultAuditingManager
默认审计管理器实现,负责管理审计作用域:
BeginScope(): 开始一个新的审计作用域Current: 获取当前审计作用域
DefaultAuditingHelper
默认审计帮助类,提供审计信息创建功能:
CreateAuditLogInfo(): 创建审计日志信息CreateAuditLogAction(): 创建审计动作信息ShouldSaveAudit(): 判断是否应该保存审计日志
JsonAuditSerializer
JSON 审计序列化器,用于序列化审计参数:
- 支持忽略敏感类型的序列化
- 支持自定义序列化配置
SparkdoAuditingOptions
审计配置选项,允许自定义审计行为:
IsEnabled: 启用/禁用审计功能HideErrors: 隐藏审计错误Contributors: 审计贡献者列表IgnoredTypes: 忽略审计的类型列表
审计存储
IAuditingStore: 审计存储接口SimpleLogAuditingStore: 简单日志审计存储实现(默认)
审计属性设置器
IAuditPropertySetter: 审计属性设置器接口DefaultAuditPropertySetter: 默认审计属性设置器实现
扩展性
该库提供了完整的审计功能实现,可以通过以下方式扩展:
- 实现自定义的
AuditLogContributor来添加特定的审计信息 - 实现自定义的
IAuditingStore来改变审计日志的存储方式 - 通过
SparkdoAuditingOptions配置审计行为 - 使用
Audited和AuditingDisable特性来控制特定类或方法的审计行为
代码结构说明
本项目包含以下主要组件:
审计信息模型
AuditLogInfo: 审计日志信息AuditLogActionInfo: 审计动作信息EntityChangeInfo: 实体变更信息EntityPropertyChangeInfo: 实体属性变更信息
核心服务
IAuditingManager: 审计管理器接口DefaultAuditingManager: 默认审计管理器实现IAuditingHelper: 审计帮助类接口DefaultAuditingHelper: 默认审计帮助类实现IAuditingStore: 审计存储接口SimpleLogAuditingStore: 简单日志审计存储实现IAuditPropertySetter: 审计属性设置器接口DefaultAuditPropertySetter: 默认审计属性设置器实现
配置
SparkdoAuditingOptions: 审计配置选项SparkdoAuditingModule: 审计模块配置
拦截器
AuditingInterceptor: 审计拦截器AuditingInterceptorRegistrar: 审计拦截器注册器
序列化
IAuditSerializer: 审计序列化器接口JsonAuditSerializer: JSON 审计序列化器实现
所有公共接口和类都添加了详细的 XML 文档注释,便于开发者理解和使用。
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- JetBrains.Annotations (>= 2025.2.2)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.0)
- Microsoft.Extensions.Configuration (>= 10.0.0)
- Microsoft.Extensions.Configuration.CommandLine (>= 10.0.0)
- Microsoft.Extensions.Configuration.EnvironmentVariables (>= 10.0.0)
- Microsoft.Extensions.Configuration.FileExtensions (>= 10.0.0)
- Microsoft.Extensions.Configuration.Json (>= 10.0.0)
- Microsoft.Extensions.Configuration.UserSecrets (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyModel (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Composite (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Embedded (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Physical (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Localization (>= 10.0.0)
- Microsoft.Extensions.Logging (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
- Nito.AsyncEx.Context (>= 5.1.2)
- Sparkdo.Auditing.Contracts (>= 1.0.1)
- Sparkdo.MultiTenancy.Abstractions (>= 1.0.1)
- Sparkdo.Security (>= 1.0.1)
- Sparkdo.Threading (>= 1.0.1)
- Sparkdo.Timing (>= 1.0.1)
- System.Linq.Dynamic.Core (>= 1.7.0)
- System.Runtime.Loader (>= 4.3.0)
- System.Text.Json (>= 10.0.0)
- TimeZoneConverter (>= 7.2.0)
-
net10.0
- JetBrains.Annotations (>= 2025.2.2)
- Microsoft.Extensions.Configuration (>= 10.0.0)
- Microsoft.Extensions.Configuration.CommandLine (>= 10.0.0)
- Microsoft.Extensions.Configuration.EnvironmentVariables (>= 10.0.0)
- Microsoft.Extensions.Configuration.FileExtensions (>= 10.0.0)
- Microsoft.Extensions.Configuration.Json (>= 10.0.0)
- Microsoft.Extensions.Configuration.UserSecrets (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyModel (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Composite (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Embedded (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Physical (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Localization (>= 10.0.0)
- Microsoft.Extensions.Logging (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
- Nito.AsyncEx.Context (>= 5.1.2)
- Sparkdo.Auditing.Contracts (>= 1.0.1)
- Sparkdo.MultiTenancy.Abstractions (>= 1.0.1)
- Sparkdo.Security (>= 1.0.1)
- Sparkdo.Threading (>= 1.0.1)
- Sparkdo.Timing (>= 1.0.1)
- System.Linq.Dynamic.Core (>= 1.7.0)
- TimeZoneConverter (>= 7.2.0)
NuGet packages (5)
Showing the top 5 NuGet packages that depend on Sparkdo.Auditing:
| Package | Downloads |
|---|---|
|
Sparkdo.Ddd.Domain
Sparkdo DDD 领域模型库,提供领域驱动设计的核心组件实现 |
|
|
Sparkdo.AutoMapper
Sparkdo AutoMapper 集成库,提供基于 AutoMapper 的对象映射功能实现 |
|
|
Sparkdo.AspNetCore
Sparkdo ASP.NET Core 集成库,提供与 ASP.NET Core 框架深度集成的功能实现 |
|
|
Sparkdo.AuditLogging.Domain
Sparkdo 审计日志领域层,提供审计日志的核心业务逻辑和数据访问接口 |
|
|
Sparkdo.Mapperly
Sparkdo Mapperly 集成库,提供基于 Mapperly 的对象映射功能实现 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.2-preview.1 | 149 | 12/4/2025 |
| 1.0.1 | 793 | 11/27/2025 |
| 1.0.0 | 790 | 11/25/2025 |
| 1.0.0-preview.5 | 96 | 10/24/2025 |