PostSharp 应用小结

PostSharp 使用IL静态注入实现AOP,

下面例子对登录操作进行静态注入,使用Web application ,记录每次登录

PostSharp的使用方法很简单,将自定义的属性 LoggerTrace直接加在需要注册的方法上就可以(事件是特殊的方法)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using PostSharpLogger;
namespace PostSharpWebForm.Account
{
    public partial class Login : Page
    {


        [LoggerTrace]
        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                RegisterHyperLink.NavigateUrl = "Register";
                OpenAuthLogin.ReturnUrl = Request.QueryString["ReturnUrl"];

                var returnUrl = HttpUtility.UrlEncode(Request.QueryString["ReturnUrl"]);
                if (!String.IsNullOrEmpty(returnUrl))
                {
                    RegisterHyperLink.NavigateUrl += "?ReturnUrl=" + returnUrl;
                }
            }
            catch (Exception)
            {

                throw;
            }
            finally
            {
                Response.Write("Hi ^<>^");
            }
        }

        protected void Page_Load2(object sender, EventArgs e)
        {
            RegisterHyperLink.NavigateUrl = "Register";
            OpenAuthLogin.ReturnUrl = Request.QueryString["ReturnUrl"];

            var returnUrl = HttpUtility.UrlEncode(Request.QueryString["ReturnUrl"]);
            if (!String.IsNullOrEmpty(returnUrl))
            {
                RegisterHyperLink.NavigateUrl += "?ReturnUrl=" + returnUrl;
            }
        }
    }
}

下面是 创建的自定义属性,具体用法可以查看PostSharp的文档

using PostSharp.Aspects;
using System;

namespace PostSharpLogger
{
    [Serializable]
    public class LoggerTraceAttribute : OnMethodBoundaryAspect
    {
        public override void OnEntry(MethodExecutionArgs args)
        {
            WriteLog.Log(string.Format("Before Entering {0}.{1}.", args.Method.DeclaringType.FullName, args.Method.Name));
            args.ReturnValue = "I'm onEntry";
            
        }
        public override void OnSuccess(MethodExecutionArgs args)
        {
            WriteLog.Log(string.Format("Before Entering {0}.{1}.", args.Method.DeclaringType.FullName, args.Method.Name));
        }
        public override void OnExit(MethodExecutionArgs args)
        {
            WriteLog.Log(string.Format(" After Entering {0}.{1}.", args.Method.DeclaringType.FullName, args.Method.Name));
            args.ReturnValue = args.MethodExecutionTag;
            args.FlowBehavior = FlowBehavior.Return;
        }

        public override void OnException(MethodExecutionArgs args)
        {
            WriteLog.Log(string.Format("Error Entering {0}.{1}.", args.Method.DeclaringType.FullName, args.Method.Name));
        }
    }
}

编译Web application 之后,使用  ILSpy查看 Web application的DLL

被注入的方法编译后变成:

using PostSharp.Aspects;
using PostSharp.Aspects.Internals;
using PostSharp.ImplementationDetails_c77a9d44;
using System;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace PostSharpWebForm.Account
{
	public class Login : Page
	{
		protected HyperLink RegisterHyperLink;
		protected OpenAuthProviders OpenAuthLogin;
		protected void Page_Load(object sender, EventArgs e)
		{
			MethodExecutionArgs methodExecutionArgs = new MethodExecutionArgs(this, new Arguments<object, EventArgs>
			{
				Arg0 = sender,
				Arg1 = e
			});
			MethodExecutionArgs arg_27_0 = methodExecutionArgs;
			MethodBase  = <>z__a_1._1;
			arg_27_0.Method = ;
			<>z__a_1.a0.OnEntry(methodExecutionArgs);
			if (methodExecutionArgs.FlowBehavior != FlowBehavior.Return)
			{
				try
				{
					try
					{
						this.RegisterHyperLink.NavigateUrl = "Register";
						this.OpenAuthLogin.ReturnUrl = base.Request.QueryString["ReturnUrl"];
						string returnUrl = HttpUtility.UrlEncode(base.Request.QueryString["ReturnUrl"]);
						if (!string.IsNullOrEmpty(returnUrl))
						{
							HyperLink expr_A4 = this.RegisterHyperLink;
							expr_A4.NavigateUrl = expr_A4.NavigateUrl + "?ReturnUrl=" + returnUrl;
						}
					}
					catch (Exception)
					{
						throw;
					}
					finally
					{
						base.Response.Write("Hi ^<>^");
					}
					<>z__a_1.a0.OnSuccess(methodExecutionArgs);
				}
				catch (Exception exception)
				{
					methodExecutionArgs.Exception = exception;
					<>z__a_1.a0.OnException(methodExecutionArgs);
					switch (methodExecutionArgs.FlowBehavior)
					{
					case FlowBehavior.Default:
					case FlowBehavior.RethrowException:
						IL_11E:
						throw;
					case FlowBehavior.Continue:
						methodExecutionArgs.Exception = null;
						return;
					case FlowBehavior.Return:
						methodExecutionArgs.Exception = null;
						return;
					case FlowBehavior.ThrowException:
						throw methodExecutionArgs.Exception;
					}
					goto IL_11E;
				}
				finally
				{
					<>z__a_1.a0.OnExit(methodExecutionArgs);
				}
			}
		}
		protected void Page_Load2(object sender, EventArgs e)
		{
			this.RegisterHyperLink.NavigateUrl = "Register";
			this.OpenAuthLogin.ReturnUrl = base.Request.QueryString["ReturnUrl"];
			string returnUrl = HttpUtility.UrlEncode(base.Request.QueryString["ReturnUrl"]);
			if (!string.IsNullOrEmpty(returnUrl))
			{
				HyperLink expr_5F = this.RegisterHyperLink;
				expr_5F.NavigateUrl = expr_5F.NavigateUrl + "?ReturnUrl=" + returnUrl;
			}
		}
		[CompilerGenerated]
		static Login()
		{
			<>z__a_1.Initialize();
		}
	}
}

  原有的方法被加载一个try catch 中

 

posted @ 2014-07-10 16:36  shzy2012  阅读(1415)  评论(0编辑  收藏  举报