Sparkdo.Authorization
1.0.2
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.Authorization --version 1.0.2
NuGet\Install-Package Sparkdo.Authorization -Version 1.0.2
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.Authorization" Version="1.0.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Sparkdo.Authorization" Version="1.0.2" />
<PackageReference Include="Sparkdo.Authorization" />
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.Authorization --version 1.0.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Sparkdo.Authorization, 1.0.2"
#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.Authorization@1.0.2
#: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.Authorization&version=1.0.2
#tool nuget:?package=Sparkdo.Authorization&version=1.0.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Sparkdo.Authorization
Sparkdo 授权库,提供基于策略和权限的授权功能实现。
功能特性
- 基于策略的授权:支持 ASP.NET Core 授权策略
- 权限系统:灵活的权限定义和检查机制
- 方法级授权:通过拦截器实现方法级别的授权控制
- 多租户支持:支持多租户场景下的授权控制
- 权限提供者:支持用户、角色、客户端等多种权限提供者
- 本地化支持:支持授权错误消息的本地化
- 与 Sparkdo 框架无缝集成
安装
<PackageReference Include="Sparkdo.Authorization" Version="x.x.x" />
核心组件
授权拦截器
AuthorizationInterceptor: 授权拦截器,用于拦截方法调用并执行授权检查AuthorizationInterceptorRegistrar: 授权拦截器注册器
授权服务
ISparkdoAuthorizationService: Sparkdo 授权服务接口DefaultSparkdoAuthorizationService: 默认 Sparkdo 授权服务实现IMethodInvocationAuthorizationService: 方法调用授权服务接口DefaultMethodInvocationAuthorizationService: 默认方法调用授权服务实现
权限管理
IPermissionChecker: 权限检查器接口DefaultPermissionChecker: 默认权限检查器实现IPermissionDefinitionManager: 权限定义管理器接口DefaultPermissionDefinitionManager: 默认权限定义管理器实现IPermissionValueProviderManager: 权限值提供者管理器接口DefaultPermissionValueProviderManager: 默认权限值提供者管理器实现
权限提供者
UserPermissionValueProvider: 用户权限值提供者RolePermissionValueProvider: 角色权限值提供者ClientPermissionValueProvider: 客户端权限值提供者
权限定义存储
IStaticPermissionDefinitionStore: 静态权限定义存储接口DefaultStaticPermissionDefinitionStore: 默认静态权限定义存储实现IDynamicPermissionDefinitionStore: 动态权限定义存储接口NullDynamicPermissionDefinitionStore: 空动态权限定义存储实现
策略提供者
ISparkdoAuthorizationPolicyProvider: Sparkdo 授权策略提供者接口DefaultSparkdoAuthorizationPolicyProvider: 默认 Sparkdo 授权策略提供者实现
状态检查器
RequirePermissionsSimpleStateChecker: 需要权限的简单状态检查器RequirePermissionsSimpleBatchStateChecker: 需要权限的批量简单状态检查器RequireAuthenticatedSimpleStateChecker: 需要认证的简单状态检查器
使用示例
基本授权使用
[Authorize("MyPermission")]
public class MyService
{
public void MyMethod()
{
// 此方法需要 "MyPermission" 权限才能访问
}
}
[Authorize("MyPermission1,MyPermission2")]
public class AnotherService
{
public void MyMethod()
{
// 此方法需要 "MyPermission1" 和 "MyPermission2" 权限才能访问
}
}
权限检查
public class MyService
{
private readonly IPermissionChecker _permissionChecker;
public MyService(IPermissionChecker permissionChecker)
{
_permissionChecker = permissionChecker;
}
public async Task MyMethod()
{
if (await _permissionChecker.IsGrantedAsync("MyPermission"))
{
// 用户具有 "MyPermission" 权限
}
}
}
自定义权限定义
public class MyPermissionDefinitionProvider : PermissionDefinitionProvider
{
public override void Define(IPermissionDefinitionContext context)
{
var myGroup = context.AddGroup("MyGroup", "我的权限组");
myGroup.AddPermission("MyPermission", "我的权限");
}
}
扩展性
该库提供了完整的授权功能实现,可以通过以下方式扩展:
- 实现自定义的权限提供者
- 实现自定义的权限定义存储
- 实现自定义的授权策略提供者
- 实现自定义的状态检查器
- 通过继承和重写默认实现来定制授权行为
所有公共接口和类都添加了详细的 XML 文档注释,便于开发者理解和使用。
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net10.0
- JetBrains.Annotations (>= 2025.2.4)
- Microsoft.AspNetCore.Authorization (>= 10.0.5)
- Microsoft.Extensions.Configuration (>= 10.0.5)
- Microsoft.Extensions.Configuration.CommandLine (>= 10.0.5)
- Microsoft.Extensions.Configuration.EnvironmentVariables (>= 10.0.5)
- Microsoft.Extensions.Configuration.FileExtensions (>= 10.0.5)
- Microsoft.Extensions.Configuration.Json (>= 10.0.5)
- Microsoft.Extensions.Configuration.UserSecrets (>= 10.0.5)
- Microsoft.Extensions.DependencyInjection (>= 10.0.5)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.5)
- Microsoft.Extensions.DependencyModel (>= 10.0.5)
- Microsoft.Extensions.Diagnostics (>= 10.0.5)
- Microsoft.Extensions.FileProviders.Composite (>= 10.0.5)
- Microsoft.Extensions.FileProviders.Embedded (>= 10.0.5)
- Microsoft.Extensions.FileProviders.Physical (>= 10.0.5)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.5)
- Microsoft.Extensions.Localization (>= 10.0.5)
- Microsoft.Extensions.Logging (>= 10.0.5)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.5)
- Microsoft.Extensions.Options (>= 10.0.5)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.5)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.5)
- Nito.AsyncEx.Context (>= 5.1.2)
- Sparkdo.Authorization.Abstractions (>= 1.0.2)
- Sparkdo.Localization (>= 1.0.2)
- System.Linq.Dynamic.Core (>= 1.7.1)
NuGet packages (4)
Showing the top 4 NuGet packages that depend on Sparkdo.Authorization:
| Package | Downloads |
|---|---|
|
Sparkdo.Ddd.Application
Sparkdo DDD应用层库,提供DDD应用服务的基础实现 |
|
|
Sparkdo.AspNetCore
Sparkdo ASP.NET Core 集成库,提供与 ASP.NET Core 框架深度集成的功能实现 |
|
|
Sparkdo.UI.Navigation
library for the Sparkdo framework |
|
|
Sparkdo.PermissionManagement.Domain
Sparkdo 权限管理领域库,提供权限管理功能的核心领域模型、仓储接口和业务逻辑实现 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.3-preview.1 | 43 | 5/17/2026 |
| 1.0.2 | 189 | 4/27/2026 |
| 1.0.2-preview.5 | 72 | 4/15/2026 |
| 1.0.2-preview.4 | 91 | 2/8/2026 |
| 1.0.2-preview.3 | 81 | 2/1/2026 |
| 1.0.2-preview.2 | 90 | 1/31/2026 |
| 1.0.2-preview.1 | 192 | 12/4/2025 |
| 1.0.1 | 538 | 11/27/2025 |
| 1.0.0 | 525 | 11/25/2025 |
| 1.0.0-preview.5 | 139 | 10/24/2025 |