在我的(现阶段)简单的c#MVC3(Razor)应用程序中出错,我似乎无法找出导致下面错误的原因。
[InvalidOperationException: Sequence contains no elements]
System.Linq.Enumerable.Last(IEnumerable`1 source) +4188046
RouteDebug.RouteDebuggerHttpModule.OnBeginRequest(Object sender, EventArgs e) +78
System.Web.SyncEventExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +148
System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +75
这就是我得到的,没有行号,没有任何内容。
我已经尝试在代码中的各个位置放置断点,包括Global.asax.cs的application_start sectin,但这些从未被命中,程序只是在我开始调试时立即用堆栈跟踪炸弹。
申请结构如下:
[Application.Core]
+Properties
+Reference
+Controllers
+Helpers
+Models
+AdminAreaRegistration.cs
+Global.asax.cs
[Application.Tests]
[Application.UI]
+Properties
+References
+App_Data
+Areas
+Admin
+Views
+Assets (css/js/images)
+Views
我已经尝试了一些建议,包括将Application.Core命名空间添加到AdminAreaRegistration.cs文件中,并删除obj / bin并重建。
我无法看到导致问题的原因。
更新
AdminAreaRegistration.cs
using System.Web.Mvc;
namespace Application.Core
{
public class AdminAreaRegistration : AreaRegistration
{
public override string AreaName
{
get
{
return "Admin";
}
}
public override void RegisterArea(AreaRegistrationContext context)
{
context.MapRoute(
"Admin_default",
"Admin/{controller}/{action}/{id}",
new {controller = "Page", action = "Index", id = UrlParameter.Optional }
);
}
}
}
的Global.asax.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Routing;
namespace Application.Core
{
// Note: For instructions on enabling IIS6 or IIS7 classic mode,
// visit http://go.microsoft.com/?LinkId=9394801
public class MvcApplication : System.Web.HttpApplication
{
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
{
filters.Add(new HandleErrorAttribute());
}
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Page", action = "Homepage", id = UrlParameter.Optional } // Parameter defaults
);
}
protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();
RegisterGlobalFilters(GlobalFilters.Filters);
RegisterRoutes(RouteTable.Routes);
}
}
}
答案 0 :(得分:2)
在反射器中查看RouteDebugger
,违规代码为:
private static void OnBeginRequest(object sender, EventArgs e)
{
if (RouteTable.Routes.Last<RouteBase>() != DebugRoute.Singleton)
{
RouteTable.Routes.Add(DebugRoute.Singleton);
}
}
所以:听起来好像你没有路线。但是,我也想知道这个模块是否应该实际使用LastOrDefault
,或者基本上能更好地应对这种情况。
您是否确保拥有RouteDebugger
的当前和最新版本?
至于为什么你没有路线:也许管道现在以不同的顺序运行?要做的第一件事:删除该模块,看看其他所有是否有效。如果该网站工作正常减去该模块,那么请问菲尔。
答案 1 :(得分:0)
这导致我在没有元素的集合上调用扩展方法Last()
,或者在没有匹配元素的集合上调用Last(expression)
。
我会搜索我的代码,尝试识别您使用此类调用的位置。 (只需在整个解决方案中进行搜索)
我最好的猜测是你将这个逻辑直接放在你的一个视图中,而不是在控制器中。