我创建了一个空的 Asp.Net MVC3 项目,并使用了 nuget install-package Ninject.MVC3
不做任何其他事情(没有注册服务,甚至没有创建 Controller )我运行应用程序。
项目在 NinjectMVC3.cs 的第 22 行中断,但出现以下异常:
[InvalidOperationException: Already Initialized!] Ninject.Web.Mvc.Bootstrapper.Initialize(Func`1 createKernelCallback) in c:\Projects\Ninject\Maintenance2.2\ninject.web.mvc\mvc3\src\Ninject.Web.Mvc\Bootstrapper.cs> :58 Mvc.App_Start.NinjectMVC3.Start() in c:\Projects\Events\Events\App_Start\NinjectMVC3.cs:22
[TargetInvocationException: Exception has been thrown by the target of an invocation.]
System.RuntimeMethodHandle._InvokeMethodFast(IRuntimeMethodInfo method, Object target, Object[] arguments, SignatureStruct& sig, MethodAttributes methodAttributes, RuntimeType typeOwner) +0
System.RuntimeMethodHandle.InvokeMethodFast(IRuntimeMethodInfo method, Object target, Object[] arguments, Signature sig, MethodAttributes methodAttributes, RuntimeType typeOwner) +72
System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture, Boolean skipVisibilityChecks) +335
System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture) +28
System.Reflection.MethodBase.Invoke(Object obj, Object[] parameters) +19
WebActivator.BaseActivationMethodAttribute.InvokeMethod() +199 WebActivator.ActivationManager.RunActivationMethods() +330 WebActivator.ActivationManager.RunPreStartMethods() +27 WebActivator.ActivationManager.Run() +39
NinjectMVC3.cs 中的行是:
public static void Start()
{
DynamicModuleUtility.RegisterModule(typeof(OnePerRequestModule));
DynamicModuleUtility.RegisterModule(typeof(HttpApplicationInitializationModule));
bootstrapper.Initialize(CreateKernel); // <- this one right here...
}
这是怎么回事?我在其他项目中使用 Ninject for MVC3 完全没有问题。我确实注意到 Start() 方法中的第二行未包含在 Ninject.MVC3 的旧(数周)包中,所以最近的更新中可能还有其他问题?
请帮忙!
编辑以解决 Remo 的回答
这是来 self 的 global.asax.cs
public class MvcApplication : System.Web.HttpApplication
{
global.asax 也是 100% 标准的。没有做任何调整。
编辑 - 问题消失了......
老实说,我不知道是什么原因造成的,但在几次重新启动 Visual Studio 并完全重新启动后,项目正常运行。我也不能在新项目中重现该问题。
抱歉浪费您的时间:)
最佳答案
看看Setting up a MVC3-application
简而言之:
您的项目中可能有一个 App_Start
文件夹,其中包含一个 NinjectMVC3.cs
文件。
当结合使用 NuGet 包和修改 Global.asax(没有理由)时,您必须删除 App_Start
文件夹并删除对 WebActivator 和 Microsoft.Web.Infrastructure 的引用
关于c# - Ninject MVC3 - Bootstrap 抛出 "Already Initialized"异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5910376/