2013-09-24 7 views
7

को पुन: सक्रिय करने के बाद मैं App_Start फ़ोल्डर में NinjectWebCommon के साथ एमवीसी 4 और निनजेक्ट 3 का उपयोग कर रहा हूं।"सर्वर त्रुटि में '/' अनुप्रयोग। अनुक्रम में कोई तत्व नहीं है" नामस्थान

और मेरे Global.asax.cs MvcApplication है: HttpApplication

मैं नीचे क्योंकि Ninject दो बार शुरू कर रहा है त्रुटि मिल रही है - क्यों?

Server Error in '/' Application. 

Sequence contains no elements 

Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. 

Exception Details: System.InvalidOperationException: Sequence contains no elements 

Source Error: 


Line 50:    kernelInstance = createKernelCallback(); 
Line 51: 
Line 52:    kernelInstance.Components.GetAll<INinjectHttpApplicationPlugin>().Map(c => c.Start()); 
Line 53:    kernelInstance.Bind<IHttpModule>().To<HttpApplicationInitializationHttpModule>(); 
Line 54:    kernelInstance.Inject(this); 

Source File: c:\Projects\Ninject\Ninject.Web.Common\src\Ninject.Web.Common\Bootstrapper.cs Line: 52 

Stack Trace: 


[InvalidOperationException: Sequence contains no elements] 
    System.Linq.Enumerable.Single(IEnumerable`1 source) +315 
    Ninject.Web.Mvc.NinjectMvcHttpApplicationPlugin.Start() in c:\Projects\Ninject\ninject.web.mvc\mvc3\src\Ninject.Web.Mvc\NinjectMvcHttpApplicationPlugin.cs:53 
    Ninject.Web.Common.Bootstrapper.<Initialize>b__0(INinjectHttpApplicationPlugin c) in c:\Projects\Ninject\Ninject.Web.Common\src\Ninject.Web.Common\Bootstrapper.cs:52 
    Ninject.Infrastructure.Language.ExtensionsForIEnumerableOfT.Map(IEnumerable`1 series, Action`1 action) in c:\Projects\Ninject\ninject\src\Ninject\Infrastructure\Language\ExtensionsForIEnumerableOfT.cs:32 
    Ninject.Web.Common.Bootstrapper.Initialize(Func`1 createKernelCallback) in c:\Projects\Ninject\Ninject.Web.Common\src\Ninject.Web.Common\Bootstrapper.cs:52 
    Company.App.App_Start.NinjectWebCommon.Start() in c:\Development\Company\trunk\src\App\App_Start\NinjectWebCommon.cs:29 

[TargetInvocationException: Exception has been thrown by the target of an invocation.] 
    System.RuntimeMethodHandle.InvokeMethod(Object target, Object[] arguments, Signature sig, Boolean constructor) +0 
    System.Reflection.RuntimeMethodInfo.UnsafeInvokeInternal(Object obj, Object[] parameters, Object[] arguments) +192 
    System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture) +108 
    System.Reflection.MethodBase.Invoke(Object obj, Object[] parameters) +19 
    WebActivator.BaseActivationMethodAttribute.InvokeMethod() +236 
    WebActivator.ActivationManager.RunActivationMethods() +534 
    WebActivator.ActivationManager.RunPreStartMethods() +41 
    WebActivator.ActivationManager.Run() +64 

[InvalidOperationException: The pre-application start initialization method Run on type WebActivator.ActivationManager threw an exception with the following error message: Exception has been thrown by the target of an invocation..] 
    System.Web.Compilation.BuildManager.InvokePreStartInitMethodsCore(ICollection`1 methods, Func`1 setHostingEnvironmentCultures) +550 
    System.Web.Compilation.BuildManager.InvokePreStartInitMethods(ICollection`1 methods) +132 
    System.Web.Compilation.BuildManager.CallPreStartInitMethods(String preStartInitListPath) +90 
    System.Web.Compilation.BuildManager.ExecutePreAppStart() +135 
    System.Web.Hosting.HostingEnvironment.Initialize(ApplicationManager appManager, IApplicationHost appHost, IConfigMapPathFactory configMapPathFactory, HostingEnvironmentParameters hostingParameters, PolicyLevel policyLevel, Exception appDomainCreationException) +516 

[HttpException (0x80004005): The pre-application start initialization method Run on type WebActivator.ActivationManager threw an exception with the following error message: Exception has been thrown by the target of an invocation..] 
    System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +9874568 
    System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +101 
    System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +254 

Version Information: Microsoft .NET Framework Version:4.0.30319; ASP.NET Version:4.0.30319.18044 

उत्तर

34

यह तब हुआ जब मैंने नामस्थान और बाइनरी नाम को दोबारा प्रतिक्रिया दी।

इसका मतलब था कि पुराने नाम के साथ डीएलएल की पुरानी प्रतिलिपि अभी भी बिन फ़ोल्डर में थी।

जिसका मतलब है कि शुरुआत में दोनों डीएल सक्रिय किए जा रहे थे।

स्वच्छ इसे हटा नहीं दिया, इसलिए मैंने मैन्युअल रूप से हटा दिया और समस्या दूर हो गई।

+2

इसके लिए आपको बहुत बहुत धन्यवाद। हालांकि, मुझे न केवल बिन फ़ोल्डर्स को हटाना पड़ा, मुझे वेब प्रोजेक्ट बनाने के लिए डिस्क क्लीन-अप चलाया गया था; मुझे लगता है कि यह अस्थायी भंडारण में पुरानी फाइलों का उपयोग कर रहा था। – contactmatt

+1

आपको बहुत धन्यवाद आदमी .... यह मेरे सिर को काट रहा था .... बहुत बहुत धन्यवाद ... – Shaz

+0

मेरे लिए वही था, मुझे एक ही समस्या थी और कोई अन्य समाधान काम नहीं किया। – brimble2010

0

मैं इस मुद्दे पर आया और इंटरनेट पर विभिन्न सिफारिशों का प्रयास करने में कुछ घंटे बिताए। अंत में तय की गई चीज़ मेरी परियोजना में नामस्थानों में परिपत्र संदर्भों की जांच करना था। अपने .csproj फ़ाइलों पर एक नज़र डालें और सभी संदर्भों को सही देखें

0

मेरे लिए मैं गलती से एक गैर वेब प्रोजेक्ट में निन्जा स्थापित कर दूंगा, इसे मेरे डेटा प्रोजेक्ट से हटाकर मेरे लिए समस्या हल हो गई।

संबंधित मुद्दे