写在前面
关于肉夹馍组件的官方介绍说明:
Rougamo是一个静态代码织入的AOP组件,同为AOP组件较为常用的有Castle、Autofac、AspectCore等,与这些组件不同的是,这些组件基本都是通过动态代理+IoC的方式实现AOP,是运行时完成的,而Rougamo是编译时直接修改目标方法织入IL代码的。如果你还知道一个AOP组件"PostSharp",那么Rougamo就是类似Postsharp的一个组件,Postsharp是一个成熟稳定的静态代码织入组件,但PostSharp是一款商业软件,一些常用的功能在免费版本中并不提供。
老规矩从NuGet 安装组件 Rougamo.Fody
代码实现
以下是最基础的一个应用肉夹馍AOP组件的实现代码
注入代码主体[LoggingAttribute]:
public class LoggingAttribute : MoAttribute
{
private static readonly NLog.Logger Logger = NLog.LogManager.GetCurrentClassLogger();
public override void OnEntry(MethodContext context)
{
// 从context对象中能取到包括入参、类实例、方法描述等信息
Logger.Info("方法执行前&