自定义 AuthorizeAttribute 依赖注入挑战
问题:
直接依赖项注入(使用属性注入)到自定义 AuthorizeAttribute
类通常会失败,导致运行时依赖属性为空。
为什么属性中的依赖注入会出现问题:
有几个因素使得对属性的依赖注入变得困难并且通常是不可取的:
-
构造函数注入不可行:属性在创建过程中无法轻易拦截,从而阻止构造函数注入。
-
时间耦合:属性注入引入了有问题的时间耦合。
-
容器验证问题:它使容器配置验证变得复杂。
-
缓存冲突:框架属性缓存可能会导致意外的依赖问题和错误。
有效的替代方案:
方法一:解耦属性(被动属性)
-
单独关注点:创建专用服务来封装逻辑并管理依赖关系。
-
属性角色:属性充当简单的包装器,解析和调用服务的方法。
方法 2:服务定位器模式
-
服务封装:将所有属性逻辑移至管理依赖项的专用服务中。
-
服务注册:使用依赖注入容器注册此服务。
-
服务解析:在属性内,使用服务定位器来解析和调用服务的方法。
最佳实践:
-
方法 1(解耦属性): 建议用于更简洁的设计,特别是在管理多个属性或跨不同程序集工作时。
-
方法 2(服务定位器):针对严格属性隔离不太重要的简单场景的实用解决方案。
通过采用这些策略,开发人员可以有效地管理依赖关系,而不会损害基于属性的代码的完整性和可维护性。
以上是如何成功地将依赖项注入自定义 AuthorizeAttributes?的详细内容。更多信息请关注PHP中文网其他相关文章!