c# 面向方面编程
AOP面向切面编程(Aspect Oriented Programming),是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。Spring框架用的核心技术就是AOP,是函数式编程的一种衍生范型。利用AOP的好处就是可以对业务逻辑进行隔离,降低耦合度,提高程序的可重用性,同时提高了开发的效率。开源的AOP也有不少,我这里用的KingAOP.
1 项目结构
2 定义一个日志记录的实体类User和LoggingAspect切面日志类

1 namespace AOPDemo.Logging
2 {
3 class User
4 {
5 public int ID { get; set; }
6 public string Name { get; set; }
7 public string Pwd{get;set;}
8 public string IP { get; set; }
9 public string State { get; set; }
10 public System.DateTime LoginTime { get; set; }
11
12 }
13 }


1 using System;
2 using System.Text;
3 using KingAOP.Aspects;
4
5 namespace AOPDemo.Logging
6 {
7 internal class LoggingAspect : OnMethodBoundaryAspect
8 {
9 public override void OnEntry(MethodExecutionArgs args)
10 {
11 string logData = CreateLogData("Entering", args);
12 Console.WriteLine(logData);
13 }
14
15 public override void OnExit(MethodExecutionArgs args)
16 {
17 string logData = CreateLogData("Leaving", args);
18 Console.WriteLine(logData);
19 }
20 /// <summary>
21 /// AOP对于登录日志逻辑,只需在此进行修改即可,无需修改被切面的处理类
22 /// </summary>
23 /// <param name="methodStage"></param>
24 /// <param name="args"></param>
25 /// <returns></returns>
26 private string CreateLogData(string methodStage, MethodExecutionArgs args)
27 {
28 var str = new StringBuilder();
29 str.AppendLine();
30 str.AppendLine(string.Format(methodStage + " {0} ", args.Method));
31 foreach (var argument in args.Arguments)
32 {
33 var argType = argument.GetType();
34
35 str.Append(argType.Name + ": ");
36
37 if (argType == typeof(string) || argType.IsPrimitive)
38 {
39 str.Append(argument);
40 }
41 else
42 {
43 foreach (var property in argType.GetProperties())
44 {
45 str.AppendFormat("{0} = {1}; ",
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 {
6 /// <summary>
7 /// 登录逻辑处理,只需添加一个LoggingAspect即可实现日志功能,达到逻辑和通用处理的逻辑分离
8 /// </summary>
9 internal class Login : IDynamicMetaObjectProvider
10 {
11 //添加登录切面
12 [LoggingAspect]
13 public void LoginValdate(User entity)
14 {
15 //只需进行业务逻辑处理,无需进行日志处理
16 if (entity.Name == "jack" && entity.Pwd == "wang")
17 {
18 entity.State = "Logged";
19 }
20 else
21 {
22 entity.State = "Error";
23 }
24
25
26 }
27 /// <summary>
28 /// IDynamicMetaObjectProvider的实现
29 /// </summary>
30 /// <param name="parameter"></param>
31 /// <returns></returns>
32 public DynamicMetaObject GetMetaObject(Expression parameter)
33 {
34 //need for AOP weaving
35 return new AspectWeaver(parameter, this);
36 }
37 }
38 }

调试代码如下:
1 //测试感觉KingAOP必须有一个dynamic才能切面
2 Logging.Login test = new Logging.Login();
3 dynamic entity = new Logging.User { Name = "Jon", ID = 99,Pwd="wang",State="",LoginTime=System.DateTime.Now};
4 test.LoginValdate(entity);
出处:http://www.cnblogs.com/isaboy/
声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
c# 面向方面编程的更多相关文章
- fir.im Weekly - 揭秘 iOS 面向协议编程
本期 fir.im Weekly 重点推荐关于 iOS 面向协议编程相关文章,还有 iOS 多线程安全.Swift 进阶.Android MVVM 应用框架.Android 蓝牙实践等技术文章分享和工 ...
- AOP 面向切面编程, Attribute在项目中的应用
一.AOP(面向切面编程)简介 在我们平时的开发中,我们一般都是面对对象编程,面向对象的特点是继承.多态和封装,我们的业务逻辑代码主要是写在这一个个的类中,但我们在实现业务的同时,难免也到多个重复的操 ...
- AOP面向切面编程的四种实现
一.AOP(面向切面编程)的四种实现分别为最原始的经典AOP.代理工厂bean(ProxyFacteryBean)和默认自动代理DefaultAdvisorAutoProxyCreator以及Bea ...
- spring入门(四)【面向切面编程】
开发过程中很多时候会用到日志.事务等操作,这些操作如果要写在业务代码中会相当麻烦,这时就会用到面向切面编程(AOP),AOP作为一种编程思想,和OOP有着不同的侧重点,面向对象侧重于万事万物皆对象,而 ...
- Atitit 面向对象编程(OOP)、面向组件编程(COP)、面向方面编程(AOP)和面向服务编程(SOP)的区别和联系
Atitit 面向对象编程(OOP).面向组件编程(COP).面向方面编程(AOP)和面向服务编程(SOP)的区别和联系 1. 面向组件编程(COP) 所以,组件比起对象来的进步就在于通用的规范的引入 ...
- 面向切面编程AOP
本文的主要内容(AOP): 1.AOP面向切面编程的相关概念(思想.原理.相关术语) 2.AOP编程底层实现机制(动态代理机制:JDK代理.Cglib代理) 3.Spring的传统AOP编程的案例(计 ...
- Spring-AOP面向切面编程
AOP是面向切面编程,区别于oop,面向对象,一个是横向的,一个是纵向. 主要解决代码分散和混乱的问题. 1.概念: 切面:实现AOP共有的类 通知:切面类中实现切面功能的方法 连接点:程序被通知的特 ...
- AOP 面向切面编程
AOP http://blog.csdn.net/xiang_j2ee/article/details/6851963 Android 支持 AspectJ 这个库来实现面向切面编程. 使用 Apac ...
- 黑马----面向方面编程AOP
黑马程序员:Java培训.Android培训.iOS培训..Net培训 JAVA反射-面向方面编程AOP 一.面向方面的需求 有如下模型: 需要统计客户登录时间.使用系统情况,或系统运行日记等信息时, ...
随机推荐
- having过滤语句
having 对部分分组来进行过滤 跟在group by 后面 在having语句中不能包含未分组的列名, select FAge,COUNT(*) from T_Employee where FS ...
- JavaScript(八)——复习一(重要内容基本包含在内)
一.常用对话框 1.alert(""):警告对话框,作用是弹出一个警告对话框 2.confirm(""):确定对话框,弹出一个带确定和取消按钮的对话框——确定返 ...
- Python 代码风格
1 原则 在开始讨论Python社区所采用的具体标准或是由其他人推荐的建议之前,考虑一些总体原则非常重要. 请记住可读性标准的目标是提升可读性.这些规则存在的目的就是为了帮助人读写代码,而不是相反. ...
- 开源监控软件ganglia安装手册
Ganglia是一个监控服务器,集群的开源软件,能够用曲线图表现最近一个小时,最近一天,最近一周,最近一月,最近一年的服务器或者集群的cpu负载,内存,网络,硬盘等指标. Ganglia的强大在于:g ...
- Hive安装(二)之表不见了
重启一下电脑,发现表不见了,原来我用的derby存储hive的meta,网上找了一下资料,说是要用mysql, 于是安装mysql sudo apt-get install mysql-serve ...
- 连载《一个程序猿的生命周期》-《发展篇》 - 3.农民与软件工程师,农业与IT业
相关文章:随笔<一个程序猿的生命周期>- 逆潮流而动的“叛逆者” 15年前,依稀记得走出大山,进城求学的场景.尽管一路有父亲的陪伴,但是内心仍然畏惧.当父亲转身离去.准备回到 ...
- 第9章 Shell基础(2)_Bash基本功能
3. Bash的基本功能 3.1 历史命令与命令补全 (1)历史命令:#history [选项] [历史命令保存文件] ①选项:-c:清空历史命令: -w:把缓存中的历史命令写入文件~/.bash_h ...
- [LeetCode] Sort Colors 颜色排序
Given an array with n objects colored red, white or blue, sort them so that objects of the same colo ...
- 【深度学习Deep Learning】资料大全
最近在学深度学习相关的东西,在网上搜集到了一些不错的资料,现在汇总一下: Free Online Books by Yoshua Bengio, Ian Goodfellow and Aaron C ...
- yii2使用小知识(连续补充)
1,打印ar或者query的原始sql: $query = (new \yii\db\Query())->select(['a.username','b.item_name'])->fro ...