zoukankan      html  css  js  c++  java
  • Unity2.0与interception的配合使用(EntLib5.0)

    引用的命名空间如下:

    建立一个帮助类:

    using Microsoft.Practices.Unity;
    using Microsoft.Practices.Unity.Configuration;

    /// <summary>
        /// 提供对UnityContainer的分装
        /// </summary>
        public sealed class OB
        {
            private static IUnityContainer _Container = null;
            /// <summary>
            /// 需要在Web.config 或 app.config中设置unity
            /// </summary>
            public static IUnityContainer Container
            {
                get
                {
                    if (_Container == null)
                    {
                        InitContainer();
                    }
                    return _Container;
                }
            }
            public static T R<T>()
            {
                return Container.Resolve<T>();
            }
            private static void InitContainer()
            {
                if (_Container == null)
                {
                    lock (typeof(OB))
                    {

                        _Container = new UnityContainer();
                        _Container.LoadConfiguration();
                    }
                }
            }
        }

    //============================

    配置文件部分

    <unity xmlns="http://schemas.microsoft.com/practices/2010/unity">
      <assembly name="F.Studio.BLL"/> <!-- 可以导入程序集,或命名空间,具体粒度看自己需求-->
      <namespace name="F.Studio.BLL"/>
      <namespace name="F.Studio.BLL.CallHandler"/>
      <sectionExtension type="Microsoft.Practices.Unity.InterceptionExtension.Configuration.InterceptionConfigurationExtension, Microsoft.Practices.Unity.Interception.Configuration"/>
      <container>
        <extension type="Interception"/>
        <!--类型部分 -->

       <!-- 单构造函数的类型注册--->
        <register type="Order">
          <lifetime type="singleton"/>
          <constructor>
            <param name="P1"/>
            <param name="name" value="aaaa"/>
          </constructor>
          <interceptionBehavior type="PolicyInjectionBehavior"/>
          <interceptor type="TransparentProxyInterceptor"/>
        </register>

        <register type="BizObj">
          <interceptionBehavior type="PolicyInjectionBehavior"/>
          <interceptor type="TransparentProxyInterceptor"/>
        </register>
        <interception>
          <policy name="policy-BizObj-1">
            <matchingRule name="invoke-rule" type="MemberNameMatchingRule">
              <constructor>
                <param name="namesToMatch">
                  <array type="string[]">
                    <value value="Submit"/>
                  </array>
                </param>
              </constructor>
            </matchingRule>
            <callHandler name="invoke-handler1" type="OrderCallHandler">
              <property name="Order" value="1"/>
            </callHandler>
          </policy>
          <policy name="policy-BizObj-2">
            <matchingRule name="invoke-rule" type="MemberNameMatchingRule">
              <constructor>
                <param name="namesToMatch">
                  <array type="string[]">
                    <value value="Agree"/>
                    <value value="Modify"/>
                    <value value="Reject"/>
                  </array>
                </param>
              </constructor>
            </matchingRule>
            <callHandler name="invoke-handler1" type="OrderCallHandler">
              <property name="Order" value="1"/>
            </callHandler>
          </policy>

         <!-- 一个策略里使用多个匹配规则
          <policy name="policy-F.Studio.BLL">
             --><!--
            <matchingRule name="invoke-rule1" type="NamespaceMatchingRule">
              <constructor>
                <param name="namespaceName" value="F.Studio.BLL" />
              </constructor>
            </matchingRule>
           --><!--
            <matchingRule name="invoke-rule2" type="TypeMatchingRule">
              <constructor>
                <param name="typeName" value="F.Studio.Client" />
              </constructor>
            </matchingRule>
            <matchingRule name="invoke-rule3" type="MemberNameMatchingRule">
              <constructor>
                <param name="namesToMatch">--><!-- 方法列表 --><!--
                  <array type="string[]">
                    <value value="Get3" />
                  </array>
                </param>
              </constructor>
            </matchingRule>
            <callHandler name="invoke-handler1" type="AuthorizationCallHandler">
              <lifetime type="singleton" />
              <property name="Order" value="1"/>
            </callHandler>
          </policy>
          -->
        </interception>
      </container>
    </unity>

    //=============================拦截处理类=========

    using Microsoft.Practices.Unity;
    using Microsoft.Practices.Unity.InterceptionExtension;
    using Microsoft.Practices.Unity.Utility;

        class AuthorizationCallHandler:ICallHandler, IDisposable
        {
            public AuthorizationCallHandler()
            {

            }

            /// <summary>
            /// 函数调用拦截处理
            /// </summary>
            /// <param name="input"></param>
            /// <param name="getNext"></param>
            /// <returns></returns>
            public IMethodReturn Invoke(IMethodInvocation input, GetNextHandlerDelegate getNext)
            {

            

                //调用前操作


                IMethodReturn methodReturn = getNext().Invoke(input, getNext);
         
                //调用后操作
                if (methodReturn.Exception == null)
                {
                    
                        //"Successfully finished {0}"
                }
                else
                {
                  
                        //"Finished {0} with exception {1}: {2}",

                }

                return methodReturn;
            }

            private int order;
            public int Order
            {
                get
                {
                    return order;
                }
                set
                {
                    order = value;
                }
            }

            public void Dispose()
            {
                //释放资源操作
            }
        }

        /// <summary>
        /// 使用特属声明时,需要定义Attribute类
        /// </summary>
        class AuthorizationCallHandlerAttribute : HandlerAttribute
        {
            /// <summary>
            /// 可以给特性类构造函数传递参数
            /// </summary>
            public AuthorizationCallHandlerAttribute()
            {

            }
            public override ICallHandler CreateHandler(IUnityContainer container)
            {
                return new AuthorizationCallHandler();
            }
        }

    //===========采用透明代理拦截器=============

    public class BizObj:MarshalByRefObject{....}

  • 相关阅读:
    JAVA获取昨天、今天、明天等日期
    IDEA设置调用方法时提示方法上的注释
    Hibernate使用distinct返回不重复的数据,使用group by 进行分组
    SpringBoot 自定义注解
    tailwindcss 使用总结
    nodejs nvm 包管理
    macos NPM 全局安装解决方案
    git 遇到修改github密码导致本地push失败解决方案
    Jupyter 快捷方式设置
    Vue indent eslint缩进webstorm冲突解决
  • 原文地址:https://www.cnblogs.com/wdfrog/p/1964464.html
Copyright © 2011-2022 走看看