首先,我们从未在开发/质量检查环境中重现这个问题.其次,部署后,这个问题似乎是不存在的.有时这个问题在部署之后的一两天内就会出现,其他的时候,这个部署将会一个个月没有出现.但是,一旦显示,那么在网站上查看的任何页面会导致错误.最后,一旦我们迁移到.NET 4.0,这个问题似乎就出现了.一年前,我们开始在2.0,高达3.5,最近升到了4.0这个解决方案和大多数孩子项目.
错误:
找不到网址为“〜/ Default.aspx”的网站地图节点.
我们的网站地图的简化版本(有些名称已更改,无趣的节点被删除)如下所示:
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0"> <siteMapNode roles="*" title="EG"> <siteMapNode url="~/../SM/Default.aspx" title="Welcome" description="" roles="*" /> <siteMapNode url="~/../SD/Default.aspx" title="SD" description="" roles="*" /> <siteMapNode url="~/../SMD/Default.aspx" title="SMD" description="" roles="*" /> <siteMapNode url="~/Default.aspx" title="Ops" description="" roles="*" > <siteMapNode url="~/Error.aspx" title="Error" hide="true" roles="*" /> <siteMapNode url="~/Public/Login.aspx" hide="true" roles="*" /> <siteMapNode url="~/Manager/LPCE.aspx" title="LPCE" description="" roles="Administrator,Manager,System,Marketer" imageUrl="~/../SM/images/icons/LF.jpg" /> </siteMapNode> <siteMapNode url="~/../SDD/Default.aspx" title="SDD" description="" roles="*" /> <siteMapNode url="~/../CCD/Default.aspx" title="CCD" description="" roles="*" /> <siteMapNode url="~/../RD/Default.aspx" title="RD" description="" roles="*"/> <siteMapNode url="~/../SBD/Default.aspx" title="SBD" description="" roles="*" /> </siteMapNode> </siteMap>
它在我们的web.config中注册:
<siteMap defaultProvider="SDXmlSiteMapProvider" enabled="true"> <providers> <add name="SDXmlSiteMapProvider" type="System.Web.XmlSiteMapProvider,System.Web,Version=2.0.0.0,Culture=neutral,PublicKeyToken=b03f5f7f11d50a3a" siteMapFile="web.sitemap" securityTrimmingEnabled="true" /> <add name="SecurityDisabledSiteMapProvider" type="System.Web.XmlSiteMapProvider,PublicKeyToken=b03f5f7f11d50a3a" siteMapFile="web.sitemap" securityTrimmingEnabled="false" /> </providers> </siteMap>
private void Page_Load(object sender,EventArgs e) { if(!IsPostBack) { SiteMapDataSource.StartingNodeUrl = "~/Default.aspx"; } }
我已经确认在所有的SiteMaps中有一个节点与url =“〜/ Default.aspx”与roles =“*”(包括公共/匿名访问),所以我很困惑为什么这个问题发生.
我考虑过的问题:
> SiteMap没有Default.aspx的节点.他们都是.
> SiteMap的Default.aspx节点由于安全原因无法访问当前用户/角色.他们都可以访问匿名用户,这个问题甚至存在于超级管理员用户.
>传入URL包含querystrings(Default.aspx?abcd).我不知道这是否是一个问题(我肯定希望不会),但一旦出现问题,我可以手写的URL,没有查询字符串,问题仍然存在.
> SiteMap更改.没有
>服务对站点地图文件的权限.部署后,该站点地图工作得很好,因此除非以IISRESET修复的方式更改权限,否则这不是问题.
>工作进程变得全局破坏.我不这么认为我们有12个网站都在同一个应用程序池中,并且问题始终保持在单个网站中.此外,我们还没有一次发生在一个单一的网站上,尽管它迄今已经在4个不同的网站中体现出来.
有人可以点亮这个吗?似乎动态编译的SiteMap似乎已经损坏或某些东西.我找到的唯一的解决方案是IISRESET或等同物.即使如此,这个问题可以解决多久就没有任何意义.这是非常令人沮丧的!
解决方法
我发现无论我做了什么“找不到具有URL”〜/ rootnode“的网站地图节点”.当我决定删除文件系统依赖关系并从恶意代码切换到sqlSiteMapProvider时,我的中断.我发现这个问题更可靠地重新创建.
总之,你得到那个消息,因为没有网站地图!我发现在siteMap数据源中,如果使用StartingNodeUrl =“〜/ root.htm”,那么当没有建立站点地图时,会出现错误信息.但是,如果您使用StartingNodeOffset =“0”,则不会显示错误消息,并且在未构建站点地图时,根本没有渲染菜单.
对我来说似乎很奇怪,但我将其追溯到XmlSiteMapProvider.有时它有时建立它没有.不能让我的头完全在帽子下,但它看起来像异步发生的事情.无论如何我已经从wickedcode切换到sqlSiteMapProvider.
我所做的一个改变,除了转换为vb之外,是对覆盖的BuildSiteMap方法的返回进行递归调用:
' Return the root SiteMapNode If _Root Is Nothing Then Return Me.BuildSiteMap Else Return _Root End If
这样可以确保建立了Sitemap.我想到了一个无限递归的守卫,但似乎并不需要.
我仍然认为可能是网络滞后或一些身份验证(在我们这个地方是通过AD控制器,并且在早晨的第一件事情上落后!!)是什么让XmlSiteMapProvider错过了它的Async构建窗口?
真的希望这有帮助.