在ABP中实现自定义拦截器(AOP)

实现Aop拦截器
首先在Domain.Shared中创建Interceptors文件夹。
创建LogInterceptor日志拦截类和LogAttribute特性类。代码结构如下:

复制代码
[Dependency(ServiceLifetime.Transient)]
public class LogInterceptor : AbpInterceptor
{
    public override async Task InterceptAsync(IAbpMethodInvocation invocation)
    {
        Console.WriteLine("方法操作前日志");
        await invocation.ProceedAsync();
        Console.WriteLine("方法操作后日志");
    }
}

[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method)]
public class LogAttribute : Attribute
{
    public LogAttribute()
    {

    }
}
复制代码

 

在模块类中的PreConfigureServices()方法中注册我们的拦截器:

复制代码
public override void PreConfigureServices(ServiceConfigurationContext context)
{
    //注册拦截器(AOP)对IOC的类进行代理
    context.Services.OnRegistred(options =>{
        if (options.ImplementationType.IsDefined(typeof(LogAttribute), true))
        {
           options.Interceptors.TryAdd<LogInterceptor>();  
        }
    } 
}
复制代码

 

 

在需要拦截的类上添加特性标记拦截:

复制代码
[LogAttribute] // 使用特性标记要拦截的类
public class MyService : ITransientDependency
{
    [LogAttribute] // 使用特性标记要拦截的方法
    public void MyMethod()
    {
        // 方法实现
    }
}
复制代码

 


————————————————
版权声明:本文为CSDN博主「琉璃知我心」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_36668541/article/details/129999753

posted @   竹林听雨行  阅读(421)  评论(2编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2020-09-20 C#6.0 Expression-bodied 函数成员
2020-09-20 如何在内插字符串中使用转义序列
2020-09-20 如何在内插表达式中使用三元条件运算符 ?:
点击右上角即可分享
微信分享提示