出处:https://www.cnblogs.com/isaboy/p/Csharp_AOP_Log.html

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# AOP框架入门(转)的更多相关文章

  1. C# AOP框架入门

    AOP面向切面编程(Aspect Oriented Programming),是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.Spring框架用的核心技术就是AOP,是函数式编程的一 ...

  2. [Spring框架]Spring AOP基础入门总结二:Spring基于AspectJ的AOP的开发.

    前言: 在上一篇中: [Spring框架]Spring AOP基础入门总结一. 中 我们已经知道了一个Spring AOP程序是如何开发的, 在这里呢我们将基于AspectJ来进行AOP 的总结和学习 ...

  3. [Spring框架]Spring AOP基础入门总结一.

    前言:前面已经有两篇文章讲了Spring IOC/DI 以及 使用xml和注解两种方法开发的案例, 下面就来梳理一下Spring的另一核心AOP. 一, 什么是AOP 在软件业,AOP为Aspect ...

  4. Spring框架入门之AOP

    Spring框架入门之AOP 一.Spring AOP简单介绍 AOP AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented ...

  5. JavaWeb框架_Struts2_(一)----->Struts2 框架入门

    1.  框架入门 2.1  Struts2简介 (1). Struts2是一种基于MVC模式的的轻量级Web开发框架. MVC模式:MVC全名是Model View Controller,是模型(mo ...

  6. Spring Security框架入门

    1.Spring Security框架入门 1.1 Spring Security简介 Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框 ...

  7. 全新升级的AOP框架Dora.Interception[2]: 基于&ldquo;约定&rdquo;的拦截器定义方式

    Dora.Interception有别于其他AOP框架的最大的一个特点就是采用针对"约定"的拦截器定义方式.如果我们为拦截器定义了一个接口或者基类,那么拦截方法将失去任意注册依赖服 ...

  8. CI框架入门1

    CI框架入门: 1.url的特点             2.目录结构/布局             3.MVC分别在哪里,如何依葫芦画瓢             4.安全性             ...

  9. 【原创】NIO框架入门(四):Android与MINA2、Netty4的跨平台UDP双向通信实战

    概述 本文演示的是一个Android客户端程序,通过UDP协议与两个典型的NIO框架服务端,实现跨平台双向通信的完整Demo. 当前由于NIO框架的流行,使得开发大并发.高性能的互联网服务端成为可能. ...

随机推荐

  1. Netty编解码技术

    编解码技术,说白了就是java序列化技术,序列化目的就两个,第一进行网络传输,第二对象持久化. 虽然我们可以使用java进行对象序列化,netty去传输,但是java序列化的硬伤比较多,比如java序 ...

  2. vue 使用a+ router.push的形式跳转时,地址栏不显示参数

    解决办法: a链接不要写href 属性

  3. 惠普/aruba交换机

    1.开启CDP cdp run show cdp neighbors可看到各端口上.下联的AP或交换机 2.配置telnet管理 1)配置IP地址 vlan 77  name "VLAN77 ...

  4. python+selenium环境安装

    目前 selenium 版本已经升级到 3.7了,网上的大部分教程是基于 2.x写的,所 以在学习前先要弄清楚版本号,这点非常重要.本系列依然以 selenium2 为基础, 目前 selenium3 ...

  5. go语言log包的学习(log,Logger)

    package main; import ( "log" "os" "time" "fmt" ) func main() ...

  6. Java(JFinal)实现sqlserver2017的数据库的备份与恢复

    1.连接数据库的代码: package com.once.xfd.dbutil; import java.sql.Connection; import java.sql.DriverManager; ...

  7. socket错误代码

    Socket error 0 - Directly send error Socket error 10004 - Interrupted function call一个封锁操作被对 WSACance ...

  8. hdu 2647 (拓扑排序 邻接表建图的模板) Reward

    题目链接http://acm.hdu.edu.cn/showproblem.php?pid=2647 老板给员工发工资,每个人的基本工资都是888,然后还有奖金,然后员工之间有矛盾,有的员工希望比某员 ...

  9. 如何修改隐藏Zblog/WordPress默认后台登录地址

    我相信很多博主站长都遇到过站点被暴力破解,虽然未被破解,但是经常收到那些尝试登录失败的邮件提醒也会心慌慌的.对于这种情况,最好的办法就是修改/隐藏我们的后台登录地址. 关于zblogASP后台登录地址 ...

  10. 超详细的PS抠图方法

    步骤: 1.打开图片,根据图片的特点选择抠图工具: 2.在图像上找到第一个定点,要求定点要完全暴露在画布中,并且是清晰可见的顶点: 3.抠取图像时,多边形套索的定点以及边线应该向内1-2个像素,为了避 ...