Не могу получить Ninject.Extensions.Interception работает

Я пытался целую вечность понять это наше. когда я пытаюсь связать свой класс с перехватчиком, я получаю следующее исключение в строке

Kernel.Bind<MyClass>().ToSelf().Intercept().With<ILoggerAspect>();

Ошибка загрузки Ninject компонента IAdviceFactory. Ни один такой компонент не был зарегистрирован в контейнере компонента ядра

Я пытался с и без LoadExtensions, с использованием модуля для настройки моих привязок и моя последняя попытка выглядит следующим образом

internal class AppConfiguration 
{

    internal AppConfiguration( )
    {
        var settings = new NinjectSettings() { LoadExtensions = false };
        Kernel = new StandardKernel(settings);
        Load();
    }

    internal StandardKernel Kernel { get; set; }

    public static AppConfiguration Instance
    {
        get { return _instance ?? (_instance = new AppConfiguration()); }
    }

    private static AppConfiguration _instance;

    private void Load()
    {
        Kernel.Bind<ILoggerAspect>().To<Log4NetAspect>().InSingletonScope();
        Kernel.Bind<MyClass>().ToSelf().Intercept().With<ILoggerAspect>();
    }

    internal static StandardKernel Resolver()
    {
        return Instance.Kernel;
    }
}

Мой Логгер Атрибут выглядит так

public class LogAttribute : InterceptAttribute
{
    public override IInterceptor CreateInterceptor(IProxyRequest request)
    {
        return request.Context.Kernel.Get<ILoggerAspect>();
    }
}

И мой перехватчик, как это

 public class Log4NetAspect : SimpleInterceptor, ILoggerAspect
{
    protected override void BeforeInvoke(IInvocation invocation)
    {
        Debug.WriteLine("Running " + invocation.ReturnValue);
        base.BeforeInvoke(invocation);
    }

    public new void Intercept(IInvocation invocation)
    {
        try
        {
            base.Intercept(invocation);
        }
        catch (Exception e)
        {
            Debug.WriteLine("Exception: " + e.Message);
        }
    }

    protected override void AfterInvoke(IInvocation invocation)
    {
        Debug.WriteLine("After Method");
        base.AfterInvoke(invocation);
    }
}

2 ответа

Решение

Скорее всего, вы не развернули Ninject.Extensions.Interception.DynamicProxy или же Ninject.Extensions.Interception.Linfu вместе с вашим заявлением [и Ninject.Extensions.Interception]. Вы должны выбрать именно один из них.

С кодом, как у вас есть сейчас (LoadExtensions=false) он не сможет подобрать определенную библиотеку перехвата - вы должны удалить ее, и обычная загрузка расширений должна подключить расширение к ядру при создании, чтобы биты перехвата могли его забрать.

В дополнение к ответу Remo Gloor, который указал мне на добавление пакета nuget для Ninject.Extensions.Interception.DynamicProxyЯ продолжал получать то же исключение, что и OP, пока не загрузил вручную DynamicProxyModule - FuncModule также загружается вручную, чтобы обойти аналогичную ошибку с заводским расширением:

_kernel = new StandardKernel(
    new NinjectSettings{LoadExtensions = true}, 
    new FuncModule(), 
    new DynamicProxyModule()); // <~ this is what fixed it
Другие вопросы по тегам