Расширение Ninject перехвата с WCF дает мне «ссылку на объект не установлена ​​на экземпляр объекта». ошибка

StackOverflow https://stackoverflow.com/questions/4297955

Вопрос

Я начинаю с расширением перехвата Ninject и не могу заставить его работать в моей службе WCF. С расширением WCF Ninject работает нормально, это перехват, который дает мне проблемы. Может быть, я делаю это неправильно? Когда я пытаюсь добавить Linfumodel в конструкторе ядра, он говорит мне, что он уже загружен, поэтому я думаю, это хорошо.

В основном все перехват на привязку разбивает мою службу WCF, но мой методинзерт только работает на сервисе (GetData () находится в договоре обслуживания).

Редактировать: следующее также не работает:

  Kernel.Intercept((request) => request.Method.Name.StartsWith("Get"))
            .With<TimingInterceptor>(); 

Конец редактирования

protected override IKernel CreateKernel()
    {
        IKernel kernel = new StandardKernel(new ServiceModule());

        //var binding = kernel.Bind<MockBroker>().ToSelf();
        //binding.Intercept().With<TimingInterceptor>(); // THIS BREAKS

        kernel.InterceptAfter<Watch>(m => m.GetData(0), i => { i.ReturnValue = "BLABLABLA"; log.Info("INTERCEPTED!"); }); //WORKS

        //kernel.Bind<Watch>().ToSelf().Intercept().With(new TimingInterceptor()); //BREAKS
        //kernel.Bind<FileSystemBroker>().ToSelf().Intercept().With<TimingInterceptor>(); //BREAKS
        return kernel;
    }

public class TimingInterceptor : SimpleInterceptor
{
    readonly Stopwatch _stopwatch = new Stopwatch();
    //private static readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
    protected override void BeforeInvoke(IInvocation invocation)
    {
        _stopwatch.Start();
    }

    protected override void AfterInvoke(IInvocation invocation)
    {
        _stopwatch.Stop();
        string message = string.Format("[Execution of {0} took {1}.]",
                                        invocation.Request.Method,
                                        _stopwatch.Elapsed);
        //log.Info(message);
       _stopwatch.Reset();
    }
}

Спасибо заранее, Райнзе

Это было полезно?

Решение

Linfu поддерживает только перехват виртуального метода. Измените все перехваченные методы для виртуального или переключения в DynamicProxy2.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top