码迷,mamicode.com
首页 > Web开发 > 详细

.net core系列之《对AOP思想的理解及使用AspectCore实现自定义日志拦截》

时间:2018-09-27 23:58:12      阅读:942      评论:0      收藏:0      [点我收藏+]

标签:lda   技术   ctc   关注   切面   代理   代码   []   http   

对于AOP这个名词,相信对于搞过MVC开发的人来说,都很熟悉,里面各种各样的Filter简直是将AOP体现到了极致。

那么什么是AOP呢?

AOP(Aspect Oriented Programming,面向切面编程),它是可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术。它是一种新的方法论,它是对传统OOP编程的一种补充。OOP是关注将需求功能划分为不同的并且相对独立,封装良好的类,并让它们有着属于自己的行为,依靠继承和多态等来定义彼此的关系;AOP是希望能够将通用需求功能从不相关的类当中分离出来,能够使得很多类共享一个行为,一旦发生变化,不必修改很多类,而只需要修改这个行为即可。AOP是使用切面(aspect)将横切关注点模块化,OOP是使用类将状态和行为模块化。在OOP的世界中,程序都是通过类和接口组织的,使用它们实现程序的核心业务逻辑是十分合适。但是对于实现横切关注点(跨越应用程序多个模块的功能需求)则十分吃力,比如日志记录,权限验证,异常拦截等。

现在我们将在.net core项目中用AspectCore来实现自定义拦截功能

github地址:https://github.com/dotnetcore/AspectCore-Framework

1、在NuGet包中搜索 AspectCore.Extensions.DependencyInjection 并安装

2、然后我们自定一个记录日志的拦截器

    public class LoggerInterceptorAttribute : AbstractInterceptorAttribute
    {
        public async override Task Invoke(AspectContext context, AspectDelegate next)
        {
            Console.WriteLine("开始记录日志");
            await next.Invoke(context);
            Console.WriteLine("结束记录日志");
        }
    }

3、然后将拦截器以特性的方式实现

    public interface IUserRepository
    {
        void GetUser();
    }
    public class UserRepository : IUserRepository
    {
        [LoggerInterceptor]
        public void GetUser()
        {
            Console.WriteLine("获取用户信息业务逻辑");
        }
    }
    static void Main(string[] args)
    {
        var userRepository = new ServiceCollection()
            .AddTransient<IUserRepository, UserRepository>()
            .BuildAspectInjectorProvider()
            .GetService<IUserRepository>();

        userRepository.GetUser();
        Console.ReadKey();
    }

结果如下:

技术分享图片 

.net core系列之《对AOP思想的理解及使用AspectCore实现自定义日志拦截》

标签:lda   技术   ctc   关注   切面   代理   代码   []   http   

原文地址:https://www.cnblogs.com/hhzblogs/p/9710611.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!