MVC4プロジェクトのglobal.asaxで依存関係リゾルバーを使用してNinject.Extensions.Logging.ILoggerへの参照を取得しようとしていますが、NullReferenceExceptionがスローされます。プロジェクトの他の場所でコンストラクターインジェクションを使用してILoggerのインスタンスを取得していますが、これは問題なく機能します。
protected void Application_EndRequest()
{
if (Context.Response.StatusCode == 404)
{
Response.Clear();
var rd = new RouteData();
rd.Values["controller"] = "Error";
rd.Values["action"] = "NotFound";
//this line throws a NullReferenceException with the stack track below
var logger = DependencyResolver.Current.GetService<ILogger>();
IController c = new ErrorController(logger);
c.Execute(new RequestContext(new HttpContextWrapper(Context), rd));
}
}
at Ninject.Extensions.Logging.LoggerFactoryBase.GetLogger(IContext context) in c:\Projects\Ninject\ninject.extensions.logging\src\Ninject.Extensions.Logging\LoggerFactoryBase.cs:line 61
at Ninject.Extensions.Logging.LoggerModuleBase.<Load>b__0(IContext context) in c:\Projects\Ninject\ninject.extensions.logging\src\Ninject.Extensions.Logging\LoggerModuleBase.cs:line 26
at Ninject.Activation.Providers.CallbackProvider`1.CreateInstance(IContext context) in c:\Projects\Ninject\ninject\src\Ninject\Activation\Providers\CallbackProvider.cs:line 45
at Ninject.Activation.Provider`1.Create(IContext context) in c:\Projects\Ninject\ninject\src\Ninject\Activation\Provider.cs:line 38
at Ninject.Activation.Context.Resolve() in c:\Projects\Ninject\ninject\src\Ninject\Activation\Context.cs:line 157
at Ninject.KernelBase.<>c__DisplayClass10.<Resolve>b__c(IBinding binding) in c:\Projects\Ninject\ninject\src\Ninject\KernelBase.cs:line 386
at System.Linq.Enumerable.WhereSelectEnumerableIterator`2.MoveNext()
at System.Linq.Enumerable.SingleOrDefault[TSource](IEnumerable`1 source)
at Ninject.Web.Mvc.NinjectDependencyResolver.GetService(Type serviceType) in c:\Projects\Ninject\ninject.web.mvc\mvc3\src\Ninject.Web.Mvc\NinjectDependencyResolver.cs:line 56
at System.Web.Mvc.DependencyResolverExtensions.GetService[TService](IDependencyResolver resolver)
at My.WebApp.MvcApplication.Application_EndRequest() in c:\Dev\Project\My.WebApp\Global.asax.cs:line 92
DependencyResolver行を次のように置き換えると機能しますが、複数のカーネルインスタンスを作成しても大丈夫ですか?
var kernel = new StandardKernel();
ILoggerFactory loggerFactory = kernel.Get<ILoggerFactory>();
var logger = loggerFactory.GetCurrentClassLogger();