当前位置: 首页 > news >正文

网站建设代理推广徽信xiala5效果好我想在百度上做广告怎么做

网站建设代理推广徽信xiala5效果好,我想在百度上做广告怎么做,asp.net网站开发与项目实战,网站建设程序流程图实现一个基于动态代理的 AOPIntro上次看基于动态代理的 AOP 框架实现#xff0c;立了一个 Flag#xff0c; 自己写一个简单的 AOP 实现示例#xff0c;今天过来填坑了目前的实现是基于 Emit 来做的#xff0c;后面有时间再写一个基于 Roslyn 来实现的示例效果演示演示代码立了一个 Flag 自己写一个简单的 AOP 实现示例今天过来填坑了目前的实现是基于 Emit 来做的后面有时间再写一个基于 Roslyn 来实现的示例效果演示演示代码切面逻辑定义:public class TryInvokeAspect : AbstractAspect {public override void Invoke(MethodInvocationContext methodInvocationContext, Action next){Console.WriteLine($begin invoke method {methodInvocationContext.ProxyMethod.Name} in {GetType().Name}...);try{next();}catch (Exception e){Console.WriteLine($Invoke {methodInvocationContext.ProxyMethod.DeclaringType?.FullName}.{methodInvocationContext.ProxyMethod.Name} exception);Console.WriteLine(e);}Console.WriteLine($end invoke method {methodInvocationContext.ProxyMethod.Name} in {GetType().Name}...);} } public class TryInvoke1Aspect : AbstractAspect {public override void Invoke(MethodInvocationContext methodInvocationContext, Action next){Console.WriteLine($begin invoke method {methodInvocationContext.ProxyMethod.Name} in {GetType().Name}...);try{next();}catch (Exception e){Console.WriteLine($Invoke {methodInvocationContext.ProxyMethod.DeclaringType?.FullName}.{methodInvocationContext.ProxyMethod.Name} exception);Console.WriteLine(e);}Console.WriteLine($end invoke method {methodInvocationContext.ProxyMethod.Name} in {GetType().Name}...);} } public class TryInvoke2Aspect : AbstractAspect {public override void Invoke(MethodInvocationContext methodInvocationContext, Action next){Console.WriteLine($begin invoke method {methodInvocationContext.ProxyMethod.Name} in {GetType().Name}...);try{next();}catch (Exception e){Console.WriteLine($Invoke {methodInvocationContext.ProxyMethod.DeclaringType?.FullName}.{methodInvocationContext.ProxyMethod.Name} exception);Console.WriteLine(e);}Console.WriteLine($end invoke method {methodInvocationContext.ProxyMethod.Name} in {GetType().Name}...);} } 测试服务定义// 测试接口定义 public interface ITestService {[TryInvokeAspect]void Test();[TryInvokeAspect][TryInvoke1Aspect][TryInvoke2Aspect]void Test1(int a, string b);[TryInvokeAspect]string Test2();[TryInvokeAspect]int Test3(); } // 测试接口实例定义 public class TestService : ITestService {[TryInvokeAspect]public virtual string TestProp { get; set; }public void Test(){Console.WriteLine(test invoked);}public virtual void Test1(int a, string b){Console.WriteLine($a:{a}, b:{b});}[TryInvoke1Aspect]public virtual string Test2(){return Hello;}[TryInvokeAspect]public virtual int Test3(){return 1;} } 测试代码//var testService ProxyGenerator.Instance.CreateInterfaceProxyITestService(); var testService ProxyGenerator.Instance.CreateInterfaceProxyITestService, TestService(); // var testService ProxyGenerator.Instance.CreateClassProxyTestService(); // testService.TestProp 12133; testService.Test(); Console.WriteLine(); testService.Test1(1, str); var a testService.Test2(); var b testService.Test3(); Console.WriteLine($a:{a}, b:{b}); Console.ReadLine(); 输出效果整体结构ProxyGeneratorProxyGenerator 代理生成器用来创建代理对象public class ProxyGenerator {public static readonly ProxyGenerator Instance new ProxyGenerator();public object CreateInterfaceProxy(Type interfaceType){var type ProxyUtil.CreateInterfaceProxy(interfaceType);return Activator.CreateInstance(type);}public object CreateInterfaceProxy(Type interfaceType, Type implementationType){var type ProxyUtil.CreateInterfaceProxy(interfaceType, implementationType);return Activator.CreateInstance(type);}public object CreateClassProxy(Type classType, params Type[] interfaceTypes){var type ProxyUtil.CreateClassProxy(classType, interfaceTypes);return Activator.CreateInstance(type);}public object CreateClassProxy(Type classType, Type implementationType, params Type[] interfaceTypes){var type ProxyUtil.CreateClassProxy(implementationType, interfaceTypes);return Activator.CreateInstance(type);} } 为了更方便的使用泛型定义了几个扩展方法public static class Extensions {public static TInterface CreateInterfaceProxyTInterface(this ProxyGenerator proxyGenerator) (TInterface)proxyGenerator.CreateInterfaceProxy(typeof(TInterface));public static TInterface CreateInterfaceProxyTInterface, TImplement(this ProxyGenerator proxyGenerator) where TImplement : TInterface (TInterface)proxyGenerator.CreateInterfaceProxy(typeof(TInterface), typeof(TImplement));public static TClass CreateClassProxyTClass(this ProxyGenerator proxyGenerator) where TClass : class (TClass)proxyGenerator.CreateClassProxy(typeof(TClass));public static TClass CreateClassProxyTClass, TImplement(this ProxyGenerator proxyGenerator) where TImplement : TClass (TClass)proxyGenerator.CreateClassProxy(typeof(TClass), typeof(TImplement)); } AbstractAspectAbstractAspect 切面抽象类继承了 Attribute可以继承它来实现自己的切面逻辑public abstract class AbstractAspect : Attribute {public abstract void Invoke(MethodInvocationContext methodInvocationContext, Action next); } MethodInvocationContextMethodInvocationContext 方法执行上下文包含了执行方法时的原始方法信息以及代理方法信息方法参数方法返回值public class MethodInvocationContext {public MethodInfo ProxyMethod { get; }public MethodInfo MethodBase { get; }public object ProxyTarget { get; }public object Target { get; }public object[] Parameters { get; }public object ReturnValue { get; set; }public MethodInvocationContext(MethodInfo method, MethodInfo methodBase, object proxyTarget, object target, object[] parameters){ProxyMethod method;MethodBase methodBase;ProxyTarget proxyTarget;Target target;Parameters parameters;} } 代理方法逻辑生成代理的方法在上一节已经介绍主要就是通过 Emit 生成代理类要写一些 Emit 代码 Emit 不在今天的讨论范围内这里不多介绍生成代理方法的时候会检查方法上的 Attribute 如果是切面逻辑就注册切面逻辑最后像 asp.net core 中间件一样组装在一起拼成一个委托。核心代码如下// var invocation new MethodInvocationContext(method, methodBase, this, parameters); var localAspectInvocation il.DeclareLocal(typeof(MethodInvocationContext)); il.Emit(OpCodes.Ldloc, localCurrentMethod); il.Emit(OpCodes.Ldloc, localMethodBase); il.Emit(OpCodes.Ldarg_0); il.Emit(OpCodes.Ldloc, localTarget); il.Emit(OpCodes.Ldloc, localParameters); // 创建一个 MethodInvocationContext 实例 il.New(typeof(MethodInvocationContext).GetConstructors()[0]); il.Emit(OpCodes.Stloc, localAspectInvocation); // AspectDelegate.InvokeAspectDelegate(invocation); il.Emit(OpCodes.Ldloc, localAspectInvocation); var invokeAspectDelegateMethod typeof(AspectDelegate).GetMethod(nameof(AspectDelegate.InvokeAspectDelegate)); // 执行方法以及注册的切面逻辑 il.Call(invokeAspectDelegateMethod); il.Emit(OpCodes.Nop); if (method.ReturnType ! typeof(void)) {// 获取方法返回值il.Emit(OpCodes.Ldloc, localAspectInvocation);var getMethod typeof(MethodInvocationContext).GetProperty(ReturnValue).GetGetMethod();il.EmitCall(OpCodes.Callvirt, getMethod, Type.EmptyTypes);if (method.ReturnType.IsValueType){// 如果是值类型做一下类型转换il.EmitCastToType(typeof(object), method.ReturnType);}il.Emit(OpCodes.Stloc, localReturnValue);il.Emit(OpCodes.Ldloc, localReturnValue); } il.Emit(OpCodes.Ret); 注册并执行切面逻辑代码实现// 缓存方法体执行的委托包含切面逻辑的执行和方法的调用 private static readonly ConcurrentDictionarystring, ActionMethodInvocationContext _aspectDelegates new ConcurrentDictionarystring, ActionMethodInvocationContext(); public static void InvokeAspectDelegate(MethodInvocationContext context) {var action _aspectDelegates.GetOrAdd(${context.ProxyMethod.DeclaringType}.{context.ProxyMethod}, m {// 获取切面逻辑这里根据切面类型做了一个去重var aspects new ListAbstractAspect(8);if (context.MethodBase ! null){// 获取类方法上的切面逻辑foreach (var aspect in context.MethodBase.GetCustomAttributesAbstractAspect()){if (!aspects.Exists(x x.GetType() aspect.GetType())){aspects.Add(aspect);}}}// 获取接口方法上的切面var methodParameterTypes context.ProxyMethod.GetParameters().Select(p p.GetType()).ToArray();foreach (var implementedInterface in context.ProxyTarget.GetType().GetImplementedInterfaces()){var method implementedInterface.GetMethod(context.ProxyMethod.Name, methodParameterTypes);if (null ! method){foreach (var aspect in method.GetCustomAttributesAbstractAspect()){if (!aspects.Exists(x x.GetType() aspect.GetType())){aspects.Add(aspect);}}}}// 构建切面逻辑执行管道类似于 asp.net core 里的请求管道 以原始方法调用作为中间件的最后一步var builder PipelineBuilder.CreateMethodInvocationContext(x x.Invoke());foreach (var aspect in aspects){// 注册切面逻辑builder.Use(aspect.Invoke);}// 构建方法执行委托return builder.Build();});// 执行委托action.Invoke(context);// 检查返回值防止切面逻辑管道的中断执行导致值类型返回值没有赋值if (context.ProxyMethod.ReturnType ! typeof(void)){if (context.ReturnValue null context.ProxyMethod.ReturnType.IsValueType){// 为值类型返回值设置默认值作为返回值context.ReturnValue Activator.CreateInstance(context.ProxyMethod.ReturnType);}} } More以上基本可以实现一个 AOP 功能但是从扩展性以及功能上来说都还比较欠缺基于 Attribute 的方式固然可以实现功能但是太不灵活如果我要在一个无法修改的接口上的某一个方法做一个切面逻辑显然只使用 Attribute 是做不到的还是 Fluent-API 的方式比较灵活。像做一层 AOP 的抽象切面逻辑通过 Fluent-API 的方式来注册大概的 API 可能是这样的var settings FluentAspects.ForITestService(); setting.PropertySetter(xx.TestProp).InterceptWithTryInterceptor().InterceptWithTryInterceptor1(); setting.Method(x x.Test2()).InterceptWithTryInterceptor().InterceptWithTryInterceptor1(); 然后基于 AspectCore 和 Castle.Core 来实现具体的 AOP 功能暂时先想一下争取尽快的发布一个基本可用的版本然后之前基于 EF Core 的自动审计也可以基于 AOP 来实现了这样就不需要显示继承 AuditDbContext 了~文章所有源码可以在 Github 上获取到Github 地址https://github.com/WeihanLi/SamplesInPractice/tree/master/AopSampleReference让 .NET 轻松构建中间件模式代码让 .NET 轻松构建中间件模式代码--支持中间件管道的中断和分支NET 下基于动态代理的 AOP 框架实现揭秘EF Core 数据变更自动审计设计AopSampleAspectCore
http://www.pierceye.com/news/472375/

相关文章:

  • 网站备案密码收不到典当 网站
  • 东莞网站建设推广服务网站建设开票单位
  • 贵港公司做网站东莞凤岗企业网站建设推广
  • 网站制作过程中碰到的问题微信怎么做链接推广产品
  • 做网站留后门是怎么回事视频网站开发需求分析
  • 关于做网站的了解点电子商务应用平台包括哪些
  • 垂直门户网站都有什么网站首页index.html
  • wordpress网站加载效果线上推销的方法
  • 网站都有什么语言杭州网络营销公司
  • 济南高新网站制作正规seo排名外包
  • 网站方案讲解技巧ppt的免费网站
  • 个人网站名称有哪些WordPress dux修改
  • 普法网站建设方案app制作开发公司怎么收费
  • 网站平台建设哪家公司好网站建设建站在线建站
  • 龙岗区住房和建设局在线网站网站如何做团购
  • 河南省建设监理协会网站证书查询wordpress 修改链接
  • 做网站业务员怎么样深圳福田最新新闻事件
  • 衡水商城网站建设外贸汽车配件做那个网站
  • 做网站的色彩搭配的小知识群艺馆网站建设方案
  • 深圳 汽车网站建设学习网站建设培训
  • 制作手机网站用什么软件唐山网站专业制作
  • 网站后台如何登陆互联网营销中心
  • 做排行榜的网站知乎长沙服务好的网络营销
  • 做网站猫要做端口映射吗太原网站建设口碑推荐
  • 新闻门户网站是什么快速搭建网页
  • 随意设计一个网站域名是什么?
  • 找人做网站需要准备什么材料用视频做网站背景
  • 大连做网站首选领超科技wordpress注册邮件发送设置
  • 西山区城市建设局网站如何做防水网站
  • 商务网站建设的组成包括自动链接 wordpress