3

我正在尝试在 .net MVC 4 应用程序中使用城堡的动态代理库来实现 AOP 日志记录。我们使用结构映射来进行依赖注入。

我已经成功地为我们的标准普通 MVC 控制器设置了 AOP 日志记录,但我们也有一个包含我们也使用的 WebAPI 控制器的文件夹。

我遇到的问题是,对于任何 WEBApi 调用,我都会收到以下错误

"Unable to cast object of type 'Castle.Proxies.IHttpControllerProxy' to type 'Web.Controllers.Services.Home.apiContollerName'.","ExceptionType":"System.InvalidCastException"

这是我的拦截器设置的设置详细信息

//Logging Interceptor in strucutremap  ObjectFactory.Initialize
x.RegisterInterceptor(new LogTypeInterceptor());

这是我的处理方法

public object Process(object target, IContext context)
    {
        var obj = new object();

        obj = _proxyGenerator.CreateInterfaceProxyWithTargetInterface(
        target.GetType().GetInterfaces().First(),
        target.GetType().GetInterfaces(),
        target, new LoggingInterceptor());

        return obj;
    }

我怀疑我需要在 _proxyGenerator 上调用不同的方法,但我是新手,不知道应该调用什么方法。

4

1 回答 1

1

问题似乎是您的代理类只模仿接口而不是基类,因此当内部 WebAPI 代码尝试将代理转换为控制器类时,代码会崩溃。如果您将呼叫替换CreateInterfaceProxyWithTargetInterface为呼叫

_proxyGenerator.CreateClassProxyWithTarget(target.GetType(), 
    target, 
    new LoggingInterceptor());

那么这个问题就会消失,但会引入一个新问题:对于没有无参数构造函数的任何类,代理创建将失败,并显示错误消息“没有为此对象定义无参数构造函数”。因此,您可能必须向所有类添加无参数构造函数。如果您可以切换到使用 Castle Windsor 作为您的 IoC,那么您可以使用拦截器和 IoC 作为一站式商店

于 2013-06-24T15:16:53.400 回答