序列不包含元素 - 堆栈跟踪中没有信息

问题描述 投票:0回答:3

在我的(现阶段)简单的 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 部分,但这些断点永远不会被命中,一旦我开始调试,程序就会立即用堆栈跟踪轰炸。

应用程序的结构如下:

[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 并重建。

我只是看不出是什么导致了问题。

更新

管理区域注册.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);
        }
    }
}
c# asp.net-mvc-3 linq debugging asp.net-mvc-3-areas
3个回答
2
投票

看一下反射器中的

RouteDebugger
,有问题的代码是:

private static void OnBeginRequest(object sender, EventArgs e)
{
    if (RouteTable.Routes.Last<RouteBase>() != DebugRoute.Singleton)
    {
        RouteTable.Routes.Add(DebugRoute.Singleton);
    }
}

所以:听起来好像你没有路线。然而,我也想知道这个模块是否应该真正使用

LastOrDefault
,或者基本上更好地应对这种情况。

您是否确保拥有最新版本的

RouteDebugger

至于为什么,你没有路线:也许管道现在以不同的顺序运行?首先要做的事情:删除该模块并查看其他所有是否有效。如果该网站在去掉该模块后工作正常,请向 Phil 询问。


0
投票

这导致我在没有元素的集合上调用扩展方法

Last()
,或者在没有匹配元素的集合上调用
Last(expression)

我会搜索我的代码,尝试确定您在哪里使用了此类调用。 (只需在整个解决方案中进行搜索即可)

我最好的猜测是,您已将此逻辑直接放入您的视图之一,而不是控制器中。


0
投票
Glancing at RouteDebugger in reflector, the offending code is:

private static void OnBeginRequest(object sender, EventArgs e)
{
    if (RouteTable.Routes.Last<RouteBase>() != DebugRoute.Singleton)
    {
        RouteTable.Routes.Add(DebugRoute.Singleton);
    }
}`enter code here`
© www.soinside.com 2019 - 2024. All rights reserved.