c# - Ninject MVC3 - Bootstrap 抛出 "Already Initialized"异常

标签 c# .net asp.net-mvc-3 ninject

我创建了一个空的 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/

相关文章:

c# - 从数据表中删除数据行

C# 浮点舍入行为

asp.net-mvc-3 - 如何使用 MVCContrib 和 Razor 制作寻呼机?

c# - Asp.Net Mvc - 如何在共享 View 中有一个 "controller"

c# - 能否使用设计模式重构此 MVC 代码?

c# - 获取 foreach 循环中的最后一项

c# - 快速的 C++ 程序,C# GUI,可能吗?

c# - SoundPlayer.Stop 不会停止声音播放

c# - 使用 WPF C# 中的多个控件组合创建自定义控件

.net - 如何在类库中定位EF生成的元文件?