AOP面向切面编程(Aspect Oriented Programming),是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。Spring框架用的核心技术就是AOP,是函数式编程的一种衍生范型。利用AOP的好处就是可以对业务逻辑进行隔离,降低耦合度,提高程序的可重用性,同时提高了开发的效率。开源的AOP也有不少,我这里用的KingAOP.
1 项目结构1 namespace AOPDemo.Logging 2 { 3 class User 4 { ID { get; set; } Name { get; set; } Pwd{get;set;} IP { get; set; } State { get; set; } 10 public System.DateTime LoginTime { get; set; } 11 12 } 13 }
1 using System; 2 using System.Text; 3 using KingAOP.Aspects; AOPDemo.Logging 6 { LoggingAspect : OnMethodBoundaryAspect 8 { OnEntry(MethodExecutionArgs args) 10 { , args); 12 Console.WriteLine(logData); 13 } OnExit(MethodExecutionArgs args) 16 { , args); 18 Console.WriteLine(logData); 19 } AOP对于登录日志逻辑,只需在此进行修改即可,无需修改被切面的处理类 CreateLogData(string methodStage, MethodExecutionArgs args) 27 { 28 var str = new StringBuilder(); 29 str.AppendLine(); , args.Method)); 31 foreach (var argument in args.Arguments) 32 { 33 var argType = argument.GetType(); ); (argType == typeof(string) || argType.IsPrimitive) 38 { 39 str.Append(argument); 40 } { 43 foreach (var property in argType.GetProperties()) 44 { , 46 property.Name, property.GetValue(argument, null)); 47 } 48 } 49 } 50 return str.ToString(); 51 } 52 } 53 }
3 Login类该类必须实现IDynamicMetaObjectProvider的GetMetaObject方法,同时在需要切面的方法上用属性[LoggingAspect]进行标注,LoggingAspect属性也就是我们上面定义的LoggingAspect切片处理类.
1 using System.Dynamic; 2 using System.Linq.Expressions; 3 using KingAOP; 4 namespace AOPDemo.Logging 5 { 登录逻辑处理,只需添加一个LoggingAspect即可实现日志功能,达到逻辑和通用处理的逻辑分离 Login : IDynamicMetaObjectProvider 10 { [LoggingAspect] LoginValdate(User entity) 14 { (entity.Name == && entity.Pwd == ) 17 { ; 19 } { ; 23 } } IDynamicMetaObjectProvider的实现 DynamicMetaObject GetMetaObject(Expression parameter) 33 { AspectWeaver(parameter, this); 36 } 37 } 38 }
调试代码如下:
Logging.Login test = new Logging.Login(); , ID = ,State="",LoginTime=System.DateTime.Now}; 4 test.LoginValdate(entity);