C# AOP微型框架实现(一)

作者在之前介绍消息、代理与AOP关系的基础上,分享自己实现的AOP微型框架。该框架通过代理实现特定预处理和后处理,作者展示了构成框架的4个.cs文件,包括定义基本AOP接口和AOP代理基类等内容。

在前面的系列文章中,我介绍了消息、代理与AOP的关系,这次将我自己实现的一个AOP微型框架拿出来和大家交流一下。

AOP的最基本功能就是实现特定的预处理和后处理,我通过代理实现了此微型框架。

先来看看构成此微型框架的4个.cs文件。

1.CommonDef.cs 用于定义最基本的AOP接口

/************************************* CommonDef.cs **************************

using System;
using System.Runtime.Remoting.Messaging ;

namespace EnterpriseServerBase.Aop
{
/// <summary>
///IAopOperator AOP操作符接口,包括前处理和后处理
///2005.04.12
/// </summary>
public interface IAopOperator
{
void PreProcess(IMessage requestMsg ) ;
void PostProcess(IMessage requestMsg ,IMessage Respond) ;
}


/// <summary>
///IAopProxyFactory 用于创建特定的Aop代理的实例,IAopProxyFactory的作用是使AopProxyAttribute独立于具体的AOP代理类。
/// </summary>
public interface IAopProxyFactory
{
AopProxyBase CreateAopProxyInstance(MarshalByRefObject obj ,Type type) ;
}

}

2. AopProxyBase AOP代理的基类,所有自定义AOP代理类都从此类派生,覆写IAopOperator接口,实现具体的前/后处理 。

using System;
using System.Runtime.Remoting ;
using System.Runtime.Remoting.Proxies ;
using System.Runtime.Remoting.Messaging ;
using System.Runtime.Remoting.Services ;
using System.Runtime.Remoting.Activation ;

namespace EnterpriseServerBase.Aop
{
/// <summary>
///AopProxyBase 所有自定义AOP代理类都从此类派生,覆写IAopOperator接口,实现具体的前/后处理 。
///2005.04.12
/// </summary>
public abstract class AopProxyBase : RealProxy ,IAopOperator
{
private readonly MarshalByRefObject target ; //默认透明代理

public AopProxyBase(MarshalByRefObject obj ,Type type) :base(type)
{
this.target = obj ;
}

#region Invoke
public override IMessage Invoke(IMessage msg)
{
bool useAspect = false ;
IMethodCallMessage call = (IMethodCallMessage)msg ;

//查询目标方法是否使用了启用AOP的MethodAopSwitcherAttribute
foreach(Attribute attr in call.MethodBase.GetCustomAttributes(false))
{
MethodAopSwitcherAttribute mehodAopAttr = attr as MethodAopSwitcherAttribute ;
if(mehodAopAttr != null)
{
if(mehodAopAttr.UseAspect)
{
useAspect = true ;
break ;
}
}
}

if(useAspect)
{
this.PreProcess(msg) ;
}

//如果触发的是构造函数,此时target的构建还未开始
IConstructionCallMessage ctor = call as IConstructionCallMessage ;
if(ctor != null)
{
//获取最底层的默认真实代理
RealProxy default_proxy = RemotingServices.GetRealProxy(this.target) ;

default_proxy.InitializeServerObject(ctor) ;
MarshalByRefObject tp = (MarshalByRefObject)this.GetTransparentProxy() ; //自定义的透明代理 this

return EnterpriseServicesHelper.CreateConstructionReturnMessage(ctor,tp);
}

IMethodReturnMessage result_msg = RemotingServices.ExecuteMessage(this.target ,call) ; //将消息转化为堆栈,并执行目标方法,方法完成后,再将堆栈转化为消息

if(useAspect)
{
this.PostProcess(msg ,result_msg) ;
}

return result_msg ;

}
#endregion

#region IAopOperator 成员

public abstract void PreProcess(IMessage requestMsg) ;
public abstract void PostProcess(IMessage requestMsg, IMessage Respond) ;
#endregion

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值