Sparkdo.AuditLogging.Domain
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.AuditLogging.Domain --version 1.0.1
NuGet\Install-Package Sparkdo.AuditLogging.Domain -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.AuditLogging.Domain" Version="1.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Sparkdo.AuditLogging.Domain" Version="1.0.1" />
<PackageReference Include="Sparkdo.AuditLogging.Domain" />
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.AuditLogging.Domain --version 1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Sparkdo.AuditLogging.Domain, 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.AuditLogging.Domain@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.AuditLogging.Domain&version=1.0.1
#tool nuget:?package=Sparkdo.AuditLogging.Domain&version=1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Sparkdo.AuditLogging.Domain
Sparkdo 审计日志领域层,提供审计日志的核心业务逻辑和数据访问接口。
功能特性
- 完整的审计日志记录功能
- 支持 HTTP 请求审计
- 支持实体变更审计
- 支持审计日志查询和分析
- 支持多租户环境
- 与 Sparkdo 框架无缝集成
安装
<PackageReference Include="Sparkdo.AuditLogging.Domain" Version="x.x.x" />
核心组件
AuditLog
审计日志实体类,记录系统操作的详细信息:
ApplicationName: 应用程序名称UserId: 用户IDUserName: 用户名TenantId: 租户IDTenantName: 租户名称ExecutionTime: 执行时间ExecutionDuration: 执行持续时间ClientIpAddress: 客户端IP地址Url: 请求URLHttpMethod: HTTP方法HttpStatusCode: HTTP状态码Exceptions: 异常信息EntityChanges: 实体变更集合Actions: 审计操作集合
EntityChange
实体变更记录类,记录实体的变更历史:
ChangeTime: 变更时间ChangeType: 变更类型(创建/更新/删除)EntityId: 实体IDEntityTypeFullName: 实体类型全名PropertyChanges: 属性变更集合
AuditLogAction
审计日志操作类,记录方法调用的操作信息:
ServiceName: 服务名称MethodName: 方法名称Parameters: 参数信息ExecutionTime: 执行时间ExecutionDuration: 执行持续时间
IAuditLogRepository
审计日志仓储接口,提供审计日志数据访问功能:
GetListAsync(): 获取审计日志列表GetCountAsync(): 获取审计日志数量GetEntityChange(): 获取实体变更信息GetEntityChangeListAsync(): 获取实体变更列表GetEntityChangesWithUsernameAsync(): 获取带用户名的实体变更历史
AuditingStore
审计存储实现类,负责将审计日志信息保存到存储中:
SaveAsync(): 保存审计日志信息
使用示例
基本配置
在模块中添加审计日志功能:
public class MyModule : Module
{
public override void ConfigureServices(IConfigureContext context)
{
// 审计日志会自动集成到框架中
// 只需确保 SparkdoAuditLoggingDomainModule 已加载
}
}
查询审计日志
public class AuditLogAppService : ApplicationService
{
private readonly IAuditLogRepository _auditLogRepository;
public AuditLogAppService(IAuditLogRepository auditLogRepository)
{
_auditLogRepository = auditLogRepository;
}
public async Task<List<AuditLog>> GetAuditLogsAsync(DateTime? startTime = null, DateTime? endTime = null)
{
return await _auditLogRepository.GetListAsync(
startTime: startTime,
endTime: endTime,
maxResultCount: 100
);
}
public async Task<List<EntityChange>> GetEntityChangesAsync(string entityId, string entityTypeFullName)
{
return await _auditLogRepository.GetEntityChangeListAsync(
entityId: entityId,
entityTypeFullName: entityTypeFullName
);
}
}
扩展性
该库提供了完整的审计日志领域实现,可以通过以下方式扩展:
- 实现自定义的
IAuditLogRepository来替换默认的数据访问实现 - 继承
AuditLog或EntityChange来添加自定义属性 - 实现自定义的
IAuditingStore来处理审计日志的存储逻辑 - 通过配置选项来调整审计日志行为
代码结构说明
本项目包含以下主要组件:
实体类
AuditLog: 审计日志实体EntityChange: 实体变更记录EntityPropertyChange: 实体属性变更记录AuditLogAction: 审计日志操作AuditLogExcelFile: 审计日志Excel文件
仓储接口
IAuditLogRepository: 审计日志仓储接口IAuditLogExcelFileRepository: 审计日志Excel文件仓储接口
核心服务
IAuditingStore: 审计存储接口AuditingStore: 审计存储实现IAuditLogInfoToAuditLogConverter: 审计日志信息转换器接口AuditLogInfoToAuditLogConverter: 审计日志信息转换器实现
常量定义
AuditLogConstants: 审计日志常量EntityChangeConstants: 实体变更常量EntityPropertyChangeConstants: 实体属性变更常量AuditLogActionConstants: 审计日志操作常量AuditLogExcelFileConstants: 审计日志Excel文件常量
辅助类
AuditLogEntityTypeFullNameConverter: 审计日志实体类型全名转换器
模块配置
SparkdoAuditLoggingDomainModule: 审计日志领域模块配置
所有公共接口和类都添加了详细的 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.Caching.Memory (>= 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 (>= 1.0.1)
- Sparkdo.AuditLogging.Domain.Shared (>= 1.0.1)
- Sparkdo.Data (>= 1.0.1)
- Sparkdo.Ddd.Domain (>= 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.Caching.Memory (>= 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 (>= 1.0.1)
- Sparkdo.AuditLogging.Domain.Shared (>= 1.0.1)
- Sparkdo.Data (>= 1.0.1)
- Sparkdo.Ddd.Domain (>= 1.0.1)
- System.Linq.Dynamic.Core (>= 1.7.0)
- TimeZoneConverter (>= 7.2.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Sparkdo.AuditLogging.Domain:
| Package | Downloads |
|---|---|
|
Sparkdo.AuditLogging.EntityFrameworkCore
Sparkdo 审计日志EntityFrameworkCore实现,提供基于EF Core的审计日志数据访问实现 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.2-preview.1 | 133 | 12/4/2025 |
| 1.0.1 | 171 | 11/27/2025 |
| 1.0.0 | 180 | 11/25/2025 |