本文继续上篇讲述一下比较复杂点的AOP例子,先新建一个控制台项目,然后同样先在Nuget中搜索安装KingAop到项目中

1、项目结构

2 、定义一个登录实体类User和LoggingAspect切面日志类

  1. public class User
  2. {
  3. public int ID { get; set; }
  4. public string Name { get; set; }
  5. public string Pwd { get; set; }
  6. public string State { get; set; }
  7. public System.DateTime LoginTime { get; set; }
  8. }
  1. /// <summary>
  2. /// 创建一个日志切面处理类
  3. /// </summary>
  4. public class LoggingAspect : OnMethodBoundaryAspect
  5. {
  6. public override void OnEntry(MethodExecutionArgs args)
  7. {
  8. string logData = CreateLogData("entering", args);
  9. Console.WriteLine(logData);
  10. }
  11.  
  12. public override void OnException(MethodExecutionArgs args)
  13. {
  14. string logData = CreateLogData("exception", args);
  15. Console.WriteLine(logData);
  16. }
  17.  
  18. public override void OnSuccess(MethodExecutionArgs args)
  19. {
  20. string logData = CreateLogData("success", args);
  21. Console.WriteLine(logData);
  22. }
  23.  
  24. public override void OnExit(MethodExecutionArgs args)
  25. {
  26. string logData = CreateLogData("exiting", args);
  27. Console.WriteLine(logData);
  28. }
  29.  
  30. /// <summary>
  31. /// AOP处理登录日志逻辑,只需在此进行修改即可,无需修改被切面的处理类
  32. /// </summary>
  33. /// <param name="methodStage"></param>
  34. /// <param name="args"></param>
  35. /// <returns></returns>
  36. private string CreateLogData(string methodStage, MethodExecutionArgs args)
  37. {
  38. var str = new StringBuilder();
  39. str.AppendLine();
  40. str.AppendLine(string.Format(methodStage + " {0} ", args.Method));
  41. foreach (var argument in args.Arguments)
  42. {
  43. //下面利用反射机制获取对象名称和对象属性和属性值
  44. var argType = argument.GetType();
  45.  
  46. str.Append(argType.Name + ": ");
  47.  
  48. if (argType == typeof(string) || argType.IsPrimitive)
  49. {
  50. str.Append(argument);
  51. }
  52. else
  53. {
  54. foreach (var property in argType.GetProperties())
  55. {
  56. str.AppendFormat("{0} = {1}; ",
  57. property.Name, property.GetValue(argument, null));
  58. }
  59. }
  60. }
  61. return str.ToString();
  62. }
  63. }

3、定义一个登录业务类Login,并且继承IDynamicMetaObjectProvider类

  1. /// <summary>
  2. /// 该类需要继承IDynamicMetaObjectProvider,因为KingAOP是基于动态类型进行操作和绑定的,如不继承是不会进入到刷选器中的相应事件里
  3. /// 登录功能,只需添加一个LoggingAspect即可实现日志功能,达到业务逻辑和通用处理逻辑的分离
  4. /// </summary>
  5. public class Login : IDynamicMetaObjectProvider
  6. {
  7. //添加处理日志切面
  8. [LoggingAspect]
  9. public void LoginValdate(User entity)
  10. {
  11. //只需进行业务逻辑处理,无需进行日志处理,日志处理交给切面处理
  12. if (entity.Name == "jack" && entity.Pwd == "wang")
  13. {
  14. entity.State = "Logged";
  15. }
  16. else
  17. {
  18. entity.State = "Error";
  19. }
  20. }
  21.  
  22. /// <summary>
  23. /// 该类必须实现IDynamicMetaObjectProvider的GetMetaObject方法
  24. /// </summary>
  25. /// <param name="parameter"></param>
  26. /// <returns></returns>
  27. public DynamicMetaObject GetMetaObject(Expression parameter)
  28. {
  29. return new AspectWeaver(parameter, this);
  30. }
  31. }

4、接下来就是测试代码,如下

  1. class Program
  2. {
  3. static void Main(string[] args)
  4. {
  5. //复杂例子
  6. Login test = new Login();
  7. dynamic entity = new User { ID = , Name = "Jon", Pwd = "wang", State = "", LoginTime = System.DateTime.Now };
  8. test.LoginValdate(entity);
  9.  
  10. Console.Read();
  11. }
  12. }

C#使用KingAOP实现AOP面向切面编程二的更多相关文章

  1. C#使用KingAOP实现AOP面向切面编程一

    AOP面向切面编程(Aspect Oriented Programming),是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术. 实现AOP主要由两种方式,一种是编译时静态植入,优点是 ...

  2. AOP 面向切面编程, Attribute在项目中的应用

    一.AOP(面向切面编程)简介 在我们平时的开发中,我们一般都是面对对象编程,面向对象的特点是继承.多态和封装,我们的业务逻辑代码主要是写在这一个个的类中,但我们在实现业务的同时,难免也到多个重复的操 ...

  3. AOP面向切面编程的四种实现

     一.AOP(面向切面编程)的四种实现分别为最原始的经典AOP.代理工厂bean(ProxyFacteryBean)和默认自动代理DefaultAdvisorAutoProxyCreator以及Bea ...

  4. Javascript aop(面向切面编程)之around(环绕)

    Aop又叫面向切面编程,其中“通知”是切面的具体实现,分为before(前置通知).after(后置通知).around(环绕通知),用过spring的同学肯定对它非常熟悉,而在js中,AOP是一个被 ...

  5. Method Swizzling和AOP(面向切面编程)实践

    Method Swizzling和AOP(面向切面编程)实践 参考: http://www.cocoachina.com/ios/20150120/10959.html 上一篇介绍了 Objectiv ...

  6. [转] AOP面向切面编程

    AOP面向切面编程 AOP(Aspect-Oriented Programming,面向切面的编程),它是可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术. ...

  7. C# AOP 面向切面编程之 调用拦截

    有时候我们需要在代码中对方法调用进行拦截,并修改参数和返回值,这种操作叫做AOP(面向切面编程) 不过需要注意的是,AOP的效率很慢,在需要高效率场合慎用. 以下是C#的AOP方法: 首先建立一个控制 ...

  8. 【原创】Android AOP面向切面编程AspectJ

    一.背景: 在项目开发中,对 App 客户端重构后,发现用于统计用户行为的友盟统计代码和用户行为日志记录代码分散在各业务模块中,比如在视频模块,要想实现对用户对监控点的实时预览和远程回放行为进行统计, ...

  9. 从壹开始前后端分离【 .NET Core2.0 +Vue2.0 】框架之十 || AOP面向切面编程浅解析:简单日志记录 + 服务切面缓存

    代码已上传Github+Gitee,文末有地址 上回<从壹开始前后端分离[ .NET Core2.0 Api + Vue 2.0 + AOP + 分布式]框架之九 || 依赖注入IoC学习 + ...

随机推荐

  1. 008——MATLAB-xlswrite的使用方法

    (一)参考文献:https://blog.csdn.net/liangjiubujiu/article/details/80455753 以矩阵A=[1 2 3 4;5 6 7 8]为例进行介绍 例1 ...

  2. Spring AOP的作用,动态代理模式

    AOP即面向切面编程.AOP是基于代理模式的. 代理模式: 当我们需要修改一个类,在类中加入代码时,为了不破坏这个类的封装性.可以使用代理模式,建立一个代理类. 比如:修改需求,在调用UserCont ...

  3. Python多线程笔记(三),queue模块

    尽管在Python中可以使用各种锁和同步原语的组合编写非常传统的多线程程序,但有一种首推的编程方式要优于其他所有编程方式即将多线程程序组织为多个独立人物的集合,这些任务之间通过消息队列进行通信 que ...

  4. NetworkX系列教程(2)-graph生成器

    小书匠Graph图论 本节主要讲解如何快速使用内置的方法生成graph,官方的文档在这里,里面包含了networkX的所有graph生成器,下面的内容只是我节选的内容,并将graph画出来而已. 声明 ...

  5. Codeforces 1153F Serval and Bonus Problem [积分,期望]

    Codeforces 思路 去他的DP,暴力积分多好-- 首先发现\(l\)没有用,所以不管它. 然后考虑期望的线性性,可以知道答案就是 \[ \int_0^1 \left[ \sum_{i=k}^n ...

  6. Allure自动化测试报告之修改allure测试报告名称

    1.从github获取allure代码 https://github.com/allure-framework/allure2 2.安装gradle,用于打包jar brew install grad ...

  7. mysql 导入导出表结构和表数据

    mysqldump -u用户名 -p密码 -d 数据库名 表名 > 脚本名; 导出整个数据库结构和数据mysqldump -h localhost -uroot -p123456 databas ...

  8. Telegraf+Influxdb+Grafana(Windows下本机简易监控系统搭建)

    1.文件名称 telegraf-1.5.0_windows_amd64.zip influxdb-1.4.2_windows_amd64.zip grafana-4.6.3.windows-x64.z ...

  9. Linux 系统配置IPv6

    1.自动获取IPV6地址 1)修改/etc/sysconfig/network文件,修改如下字段,不存在则手动添加,部分系统默认是开启的NETWORKING_IPV6=yes 2)修改/etc/sys ...

  10. arcgis python 布局中所有元素信息报告

    # Author: ESRI # Date: July 5, 2010 # Version: ArcGIS 10.0 # Purpose: This script generates a report ...