ABP框架学习记录(26)- Authorization 解析
本文 以 Volo.Abp
解决方案展开研究;
在 Volo.Abp
解决方案中,提供了单独的项目 实现 Authorization
功能,如下图:
data:image/s3,"s3://crabby-images/db1a2/db1a2de76f44b2c53922e945a28c2d39267e3ef2" alt="QQ截图20191017152520.png"
Authorization
:中文解释,授权。ABP 中检查是否对 用户或者角色
授予权限。整个功能可以分为两个方面理解:
1,许可定义;
2,检查许可;
Permission
Permission
的中文解释为:许可,允许。
首先介绍 Permission
相关的类定义:
PermissionDefinition
:许可定义,包括父级权限和子级列表。
data:image/s3,"s3://crabby-images/0c06d/0c06d425e63b729de3409d8e84e4cdd5fe54d46f" alt="QQ截图20191021114332.png"
PermissionGroupDefinition
:定义许可组;
data:image/s3,"s3://crabby-images/667ae/667ae44f4704febbd5f40db8d072e90f4d34005a" alt="QQ截图20191021131218.png"
PermissionGrantResult
:授权结果;
data:image/s3,"s3://crabby-images/ff634/ff63456004bb8c11b2a7c700b1a85e3bccc1bfc1" alt="QQ截图20191021131648.png"
IPermissionChecker
:检查授权,提供 IsGrantedAsync
方法检查是否有权限。
data:image/s3,"s3://crabby-images/96395/963952e0f93950ae2195cd5b41d144ed06e93243" alt="QQ截图20191021104232.png"
PermissionChecker
:实现 IPermissionChecker
接口;
data:image/s3,"s3://crabby-images/1e6d7/1e6d728e78a6dc83a1c3bb26839093928f51a161" alt="QQ截图20191021131755.png"
IPermissionDefinitionContext
:许可定义上下文,封装了 PermissionGroupDefinition
对象,并且提供了添加,移除的方法;
data:image/s3,"s3://crabby-images/f52b6/f52b60c0518b25a3e3f0641a3a82bc1a5264faca" alt="QQ截图20191021132317.png"
PermissionDefinitionContext
:实现 IPermissionDefinitionContext
接口;
data:image/s3,"s3://crabby-images/9f21b/9f21b27c083bac04fdf5f7ca30a51df16f11effc" alt="QQ截图20191021132414.png"
IPermissionDefinitionManager
:管理 PermissionDefinition
;
data:image/s3,"s3://crabby-images/65460/654608d1e88c211eaffc379eaa7e35693c400e2e" alt="QQ截图20191021135949.png"
PermissionDefinitionManager
:默认实现 IPermissionDefinitionManager
接口。
data:image/s3,"s3://crabby-images/d2457/d2457486e0865a9b4a7c14190b4db62f8356ff00" alt="QQ截图20191021140150.png"
IPermissionDefinitionProvider
:定义 PermissionDefinition
提供者接口;对 Define
方法传入的 IPermissionDefinitionContext
对象进行操作;
data:image/s3,"s3://crabby-images/1e5cb/1e5cba3122f2f18c1801e297b35b2ce810b6bc1f" alt="QQ截图20191021140648.png"
PermissionDefinitionProvider
:实现 IPermissionDefinitionProvider
接口;
data:image/s3,"s3://crabby-images/cec86/cec865db049e0cb0c6e054baa8078551b163eec1" alt="QQ截图20191021140742.png"
IPermissionStore
:定义许可 存储接口;
data:image/s3,"s3://crabby-images/6dbed/6dbedfea70b52ba2c3a44b216d6c48ff71f792b3" alt="QQ截图20191021141034.png"
NullPermissionStore
:IPermissionStore
接口的空实现。
IPermissionValueProvider
:定义获取 PermissionValue
的接口;
data:image/s3,"s3://crabby-images/9587e/9587e8d98cd03048fc533f9d24600f252ed3b2c6" alt="QQ截图20191021151209.png"
PermissionValueProvider
:实现 IPermissionValueProvider
接口;
data:image/s3,"s3://crabby-images/72e00/72e0061292609897d6c724a1d97194ecc1b7f22e" alt="QQ截图20191021171013.png"
RolePermissionValueProvider
:提供角色相关许可;
UserPermissionValueProvider
:提供用户相关许可;
ClientPermissionValueProvider
:提供客户端相关许可;
IPermissionValueProviderManager
:定义管理 IPermissionValueProvider
的接口;
data:image/s3,"s3://crabby-images/48ced/48cedc74b626ef5a9d2cc55abdfb951ed2d6b035" alt="QQ截图20191021171140.png"
PermissionValueProviderManager
:实现 IPermissionValueProviderManager
接口;
data:image/s3,"s3://crabby-images/f9a48/f9a48248ae0b772d2e8b1e27d4a885bacda2a697" alt="QQ截图20191021171437.png"
PermissionOptions
:许可选项;
data:image/s3,"s3://crabby-images/4f8f0/4f8f051748f32855f22b6f77bf2439521c012d15" alt="QQ截图20191021141758.png"
PermissionValueCheckContext
:检查 PermissionValue
的上下文;
data:image/s3,"s3://crabby-images/5d499/5d499043fafb8ce9c630cf2a9d6d08473eec00f9" alt="QQ截图20191021171820.png"
AbpAuthorizationModule
这一部分主要分析 AbpAuthorizationModule
的实现。
在 Volo.Abp
解决方案中,其 Module
系统集成 Core 自带的 IServiceCollection
,通过自定义的 ServiceConfigurationContext
类,封装了 IServiceCollection
对象:
data:image/s3,"s3://crabby-images/38860/3886072f487d46fdae214cc53f5d4613ebe073ea" alt="QQ截图20191021175125.png"
AbpAuthorizationModule
:定义Module
,OnRegistred
扩展方法 添加 拦截器注册者;
data:image/s3,"s3://crabby-images/33155/331551be3d9971fe3e18fe4b4789c4eca2365644" alt="QQ截图20191021174716.png"
AuthorizationInterceptorRegistrar
:拦截器注册类;
data:image/s3,"s3://crabby-images/a9354/a9354c20915e76e888c9d16658d82215a6a98bb3" alt="QQ截图20191021175737.png"
AuthorizationInterceptor
:定义拦截器;
data:image/s3,"s3://crabby-images/3b203/3b203b0dd5c292c61fa2414827109cf5b8c1b076" alt="QQ截图20191021175839.png"
MethodInvocationAuthorizationContext
:定义方法调用 许可上下文,校验方法是否被允许;
data:image/s3,"s3://crabby-images/18083/180834b6fd4718cea8310e582ed442f827bcd20e" alt="QQ截图20191021180118.png"
IMethodInvocationAuthorizationService
:定义校验方法许可的接口;
MethodInvocationAuthorizationService
:实现 IMethodInvocationAuthorizationService
接口;
data:image/s3,"s3://crabby-images/99e95/99e956634c97ad046b05236305e5e909bfc31b60" alt="QQ截图20191021180541.png"
data:image/s3,"s3://crabby-images/8e90f/8e90fc487dd6a29d8541223e092126a61ec6091a" alt="QQ截图20191021180851.png"
PermissionRequirement
:许可参数;
data:image/s3,"s3://crabby-images/15de5/15de51b6b91e540443105b3fb19eda35ab6a6053" alt="QQ截图20191021181401.png"
PermissionRequirementHandler
:定义 回调 Handler
;
data:image/s3,"s3://crabby-images/d21f3/d21f3411beeba86b038d76d4ff471299dad2dc20" alt="QQ截图20191021181600.png"
其它
IAbpAuthorizationService
:定义 Abp
授权服务接口;继承 Dot Net Core自带 IAuthorizationService
接口;
AbpAuthorizationService
:实现 IAuthorizationService
接口;
data:image/s3,"s3://crabby-images/7178e/7178e858c4f1afd56a37a8cb9fa3ae17cd20d089" alt="QQ截图20191021182258.png"
IAbpAuthorizationPolicyProvider
:定义 授权 策略 提供者接口;继承 Dot Net Core 自带 IAuthorizationPolicyProvider
接口;
AbpAuthorizationPolicyProvider
:实现 IAbpAuthorizationPolicyProvider
接口;
data:image/s3,"s3://crabby-images/722a1/722a19256f3364749c66c44be4a4df8674f97164" alt="QQ截图20191021182527.png"