zoukankan      html  css  js  c++  java
  • .net动态代理-EMIT,AOP实现

    动态代理实现原理:

      通过动态基础目标类,重写目标虚方法,.net中实现手段-il

      Emit.Proxy项目源码,https://github.com/1448376744/Emit.Proxy

      以下是基于Emit.Proxy实现的Demo

      class Program
        {
            static void Main(string[] args)
            {
                Console.WriteLine("Hello World!");
                var generator = new ProxyGenerator();
                //多实例拦截器
                var service = generator.CreateInstanse<Service>(new TransactionInterceptor());
                service.DelUser();
            }
        }
    
        public class Service
        {
            public virtual void UpdateUser()
            {
                Console.WriteLine("用户已修改");
            }
            public virtual void DelUser()
            {
                Console.WriteLine("用户已删除");
            }
        }
        public class TransactionInterceptor : IInterceptor
        {
            private DbConnection Connection { get; set; }
            public DbTransaction Transaction { get; set; }
            public void Intercept(IInvocation invocation)
            {
                try
                {
                    if (Connection == null)
                    {
                        Connection = new MySql.Data.MySqlClient.MySqlConnection("server=127.0.0.1;user id=root;password=1024;database=test;pooling=true;");
                        Connection.Open();
                        Console.WriteLine("事务已开启");
                        Transaction = Connection.BeginTransaction();
                    }
                    //执行目标方法
                    invocation.Proceed();
                    Transaction?.Commit();
                    Console.WriteLine("事务提交了...");
                }
                catch (Exception e)
                {
                    Console.WriteLine("异常:{0}",e.Message);
                    //回滚事务
                    Transaction?.Rollback();
                    Console.WriteLine("事务回滚了");
                    //记录日志:NLog
                    Console.WriteLine();
                }
                finally
                {
                    Connection?.Close();
                }
            }
        }
    
  • 相关阅读:
    [Qt]《开发指南》3.1源码分析
    [c++] 头文件
    [Qt] 信号和槽
    [Qt] 编译问题
    [Qt] 项处理组件
    MYSQL 之 JDBC(十三):处理事务
    MYSQL 之 JDBC(十二): 处理Blob
    MYSQL 之 JDBC(十一): JDBC获取插入记录的主键值
    MYSQL 之 JDBC(十): JDBC的元数据
    MYSQL 之 JDBC(九):增删改查(七)DAO的补充和重构
  • 原文地址:https://www.cnblogs.com/chaeyeon/p/10986471.html
Copyright © 2011-2022 走看看