Castle.DynamicProxy 拦截器

前言:我们已经使用工厂模式得到需要的service对象,以下方法可以通过Castle.DynamicProxy给service对象的方法添加拦截器。

/// <summary>
/// 创建服务根据BLL接口
/// </summary>
public static T CreateService<T>() where T : class
{
    var service = serviceFactory.CreateService<T>();

    //拦截,可以写日志....
    var generator = new ProxyGenerator();
    var dynamicProxy = generator.CreateInterfaceProxyWithTargetInterface<T>(
        service, new InvokeInterceptor());

    return dynamicProxy;
}

internal class InvokeInterceptor : IInterceptor
{
    public InvokeInterceptor(){}
    /// <summary>
    /// 拦截方法
    /// </summary>
    /// <param name="invocation"></param>
    public void Intercept(IInvocation invocation)
    {
        try
        {
            invocation.Proceed();
        }
        catch (Exception exception)
        {
            if (exception is BusinessException)
                throw;

            var message = new
            {
                exception = exception.Message,
                exceptionContext = new
                {
                    method = invocation.Method.ToString(),
                    arguments = invocation.Arguments,
                    returnValue = invocation.ReturnValue
                }
            };

            Log4NetHelper.Error(LoggerType.ServiceExceptionLog, message, exception);
            throw;
        }
    }
}

倘若我们调用service对象的某个执行方法,则先会执行InvokeInteceptor的Intercept方法~当执行到该方法的invocation.Proceed();才会去执行实际我们需要执行的代码。这就是所谓的拦截。

时间: 2024-10-13 14:31:29

Castle.DynamicProxy 拦截器的相关文章

ASP.NET Core搭建多层网站架构【8.2-使用Castle.Core实现动态代理拦截器】

2020/01/30, ASP.NET Core 3.1, VS2019, 摘要:基于ASP.NET Core 3.1 WebApi搭建后端多层网站架构[8.2-使用Castle.Core实现动态代理拦截器] 使用Autofac替换原生的依赖注入 文章目录 此分支项目代码 本章节介绍了使用Autofac代替原生的依赖注入,使用Autofac为的是后面配合Castle.Core做AOP动态代理 原文地址:https://www.cnblogs.com/kasnti/p/12244544.html

基于Autofac, Castle.DynamicProxy的动态WCF解决方案(原创)

本方案解决了下面3个主要的问题: 1.减少配置,为了避免每次新增service都需要去修改配置文件,包括服务器端跟各个客户端的. 2.能够使用函数重载,泛型函数,以及泛型类. 3.使项目能够快速地在wcf与直接调用dll之间切换. 整个解决方案分为四块内容:1.客户端,2.契约层,3.服务端,4.实现层 1.客户端:只能看到契约层,而看不到具体的实现:但也可以通过直接引用实现层,从而脱离wcf(需要修改工厂方法,也可以改进一下,通过配置文件来做这个事情,但这个不是本解决方案的重点,有兴趣的可以自

AOP之Castle DynamicProxy 动态代理

这里主要介绍使用castle这个动态代理,在.net一些开源的框架里可以找到它的影子,就连微软的rchard也是使用这个进行方法拦截等可以基于这个进行方法拦截,在这个方面PostSharp算是比较好用的,可以跟使用属性一样使用没有代码侵入,可是这个是收费,postsharp使用的是运行时注入,这个在之前的文章已经说过这里不再重复说,这里就直接进入正题. 这里介绍先DynamicProxy的方法拦截功能先来个例子 先定义一个类 public class MyClass : IMyClass { p

.NET 简易方法拦截器

伟大的无产阶级Willaim曾说过:"无论你觉得自己多么的了不起,也永远有人比你更强".对,我说过!我就是william. 今天想记录一下在项目中遇到的一个比较有意思的东西,异常拦截器(也不能完全说只是异常拦截,准确的说应该叫方法拦截),那有的人可能会说,异常拦截器不就是用Try--Catch就好了吗?没错,Try--Catch是能拦截到异常.如果只是简单拦截下,这种方法简单可行.但是我们如果扩展下,所有的异常都要统一处理,如果你是架构师,你的团队需要你提供一个公共的异常拦截处理组件,

基于Dynamic Proxy技术的方法AOP拦截器开发

在面向对象编程中,会用到大量的类,并且会多次调用类中的方法.有时可能需要对这些方法的调用进行一些控制.如在权限管理中,一些用户没有执行某些方法的权限.又如在日志系统中,在某个方法执行完后,将其执行的结果记录在日志中.处理这些需求的一般做法是在调用这些方法的地方加上适当的代码.如以下C#代码如示: 1 public class Class1 2 { 3 public void MyMethod() 4 { 5 ... 6 } 7 static void Main() 8 { 9 Class1 c1

【Autofac打标签模式】Aspect拦截器

[ Autofac打标签模式]开源DI框架扩展地址: https://github.com/yuzd/Autofac.Annotation/wiki 前提条件 自己new一个对象不能实现拦截器功能,必须得从DI容器拿到的对象才能具备拦截器功能 可以参考 我写的文章介绍 拦截器原理简单介绍 用了Castle.Core组件 把你想要实现拦截器的目标类生成一个代理类. 然后织入拦截器,有2种方式 class + 方法为virtual的方式 这种方式需要 从容器中是根据一个classType来获取到目标

java web 过滤器跟拦截器的区别和使用

1.首先要明确什么是拦截器.什么是过滤器 1.1 什么是拦截器: 拦截器,在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作.拦截是AOP的一种实现策略. 在Webwork的中文文档的解释为--拦截器是动态拦截Action调用的对象.它提供了一种机制可以使开发者可以定义在一个action执行的前后执行的代码,也可以在一个action执行前阻止其执行.同时也是提供了一种可以提取action中可重用的部分的方式.

微信小程序之页面拦截器

场景 小程序有52个页面,其中13个页面无需任何身份,另外39个页面需要系统角色.对于这39个页面,如果微信用户没有系统角色,则跳转到登录页.是否有系统角色信息需要通过异步请求来获取. 需求分析&实现 对需求进行抽象,其实要的就是一个过滤器,对小程序页面的访问进行过滤,符合条件的通过,不符合条件进行其他处理. 使用过php的laravel框架的童鞋,肯定一下子就联想到了laravel框架的http中间件:HTTP 中间件提供一个方便的机制来过滤进入应用程序的 HTTP 请求,例如,Laravel

SpringMvc拦截器小测试

前言 俗话说做项目是让人成长最快的方案,最近小编写项目的时候遇到了一个小问题.小编在项目中所负责的后台系统,但是后台系统是通过系统的页面是通过ifame联动的,那么这时候问题就来了,后台所做的所有操作都是联动操作(都是基于所联动的)那么我后台所做的所有操作都是基于后台用户登录的情况下所做的.但是在联动中中所有页面都是单独存在的,如果要解决这个问题就需要在做操作之前判断用后台用户是否已经登录.想知道小编是如何实现的那就接着往下看. 简介 Spring MVC的拦截器不仅可实现Filter的所有功能