AspectCore动态代理中的拦截器详解(一)
前言
在上一篇文章使用AspectCore動(dòng)態(tài)代理中,簡(jiǎn)單說(shuō)明了AspectCore.DynamicProxy的使用方式,由于介紹的比較淺顯,也有不少同學(xué)留言詢問(wèn)攔截器的配置,那么在這篇文章中,我們來(lái)詳細(xì)看一下AspectCore中的攔截器使用。
兩種配置方式
在AspectCore中,提供攔截器的特性配置和全局配置兩種使用方式,并且分別提供AbstractInterceptor(可用于全局?jǐn)r截器配置)和AbstractInterceptorAttribute(可同時(shí)用于全局配置和特性配置)兩個(gè)攔截器基類。下面來(lái)分別演示兩個(gè)攔截器配置方式的使用:
特性攔截器。我們繼承AbstractInterceptorAttribute來(lái)實(shí)現(xiàn)一個(gè)自己的特性攔截器
? ?public override Task Invoke(AspectContext context, AspectDelegate next) ? ? { ? ? ?
? ? ?? return context.Invoke(next);}}
那么此時(shí)CustomInterceptorAttribute可以標(biāo)記在需要攔截的接口,類或者方法上來(lái)開(kāi)啟攔截。
全局?jǐn)r截器配置。我們繼承AbstractInterceptor來(lái)實(shí)現(xiàn)一個(gè)自己的特性攔截器(除不能作為Attribute標(biāo)記在口,類或者方法上之外,AbstractInterceptor和AbstractInterceptorAttribute并無(wú)任何區(qū)別)
? ? public override Task Invoke(AspectContext context, AspectDelegate next){ ? ?
? ? ? ? return context.Invoke(next);}}
現(xiàn)在我們已經(jīng)定義了我們自己的攔截器,我使用Microsoft.Extensions.DependencyInjection的集成方式來(lái)演示全局?jǐn)r截器的配置(需安裝AspectCore.Extensions.DependencyInjection包):
IServiceCollection services = new ServiceCollection(); services.AddDynamicProxy(config => {config.Interceptors.AddTyped<CustomInterceptor>(); }); IServiceProvider serviceProvider = services.BuildAspectCoreServiceProvider();CustomInterceptor便可以攔截由serviceProvider創(chuàng)建的任何服務(wù)的方法。
三種攔截器類型
在AspectCore中,提供了TypedInterceptor,ServiceInterceptor,DelegateInterceptor三種攔截器的激活類型。
TypedInterceptor
標(biāo)記在接口,類或者方法上的特性攔截器或者使用上面config.Interceptors.AddTyped<CustomInterceptor>();配置的全局?jǐn)r截器,這類攔截器對(duì)于每個(gè)方法具體唯一的實(shí)例。ServiceInterceptor
注冊(cè)到DI并從DI激活使用的攔截器。這類攔截器的生命周期同注冊(cè)到DI時(shí)的生命周期一致。如下面我們注冊(cè)一個(gè)瞬態(tài)的ServiceInterceptor:
我們可以使用ServiceInterceptor特性激活注冊(cè)到DI中的攔截器:
[ServiceInterceptor(typeof(CustomInterceptor))]public interface IService{ ? ?void Foo(); }或者使用全局配置:
IServiceCollection services = new ServiceCollection();services.AddTransient<CustomInterceptor>();services.AddDynamicProxy(config =>{config.Interceptors.AddServiced<CustomInterceptor>();});IServiceProvider serviceProvider = services.BuildAspectCoreServiceProvider();DelegateInterceptor
在使用全局的攔截器配置時(shí),我們也可以不定義具體的攔截器類,而直接使用簽名為Func<AspectDelegate, AspectDelegate>或Func<AspectContext, AspectDelegate, Task>的委托來(lái)執(zhí)行攔截,如下面:
? ? ? ?await content.Invoke(next);}); }); IServiceProvider serviceProvider = services.BuildAspectCoreServiceProvider();
使用通配符或者委托配置攔截器
在AspectCore中配置全局?jǐn)r截器時(shí),可以使用通配符或者委托來(lái)限定攔截器的作用范圍。
內(nèi)置提供了Predicates.ForMethod,Predicates.ForService,Predicates.ForNameSpace三個(gè)通配符函數(shù):
有問(wèn)題反饋
如果您有任何問(wèn)題,請(qǐng)?zhí)峤?Issue?給我們。
Github :?https://github.com/dotnetcore/AspectCore-Framework
AspectCore QQ群: 306531723
相關(guān)文章
Asp.Net Core輕量級(jí)Aop解決方案:AspectCore
AspectCore.Extension.Reflection : .NET Core反射擴(kuò)展庫(kù)
AspectCore中的IoC容器和依賴注入
使用AspectCore動(dòng)態(tài)代理
原文:https://www.cnblogs.com/liuhaoyang/p/interceptor-in-aspectcore-part-1.html
.NET社區(qū)新聞,深度好文,歡迎訪問(wèn)公眾號(hào)文章匯總 http://www.csharpkit.com
總結(jié)
以上是生活随笔為你收集整理的AspectCore动态代理中的拦截器详解(一)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: C# 这些年来受欢迎的特性
- 下一篇: Actor-ES框架:Ray