有没有人有创建基于SQL的ASP.NET站点地图提供程序的经验?
我有默认的XML文件web.sitemap
与我的Menu和SiteMapPath控件正常工作,但我需要一种方法让我的网站用户动态创建和修改页面。
我还需要将页面查看权限绑定到标准的ASP.NET
会员系统中。
来自MSDN杂志的Jeff Prosise版本运行良好,但它有一些缺陷:
AddNode
在菜单上链接到外部网站(www.google.com等)
这是我在BuildSiteMap()
的修复:
SiteMapNode node = GetSiteMapNodeFromReader(reader);
string url = node.Url;
if (url.Contains(":"))
{
string garbage = Guid.NewGuid().ToString(); // SiteMapNode needs unique URLs
node.Url = "~/dummy_" + garbage + ".aspx";
AddNode(node, _root);
node.Url = url;
}
else
{
AddNode(node, _root);
}
SQLDependency
缓存很酷,但是如果你不想每次加载菜单都去DB时(检查依赖关系是否已经改变)并且菜单不经常更改,那么为什么不使用HttpRuntime.Cache
代替?
public override SiteMapNode RootNode
{
get
{
SiteMapNode temp = (SiteMapNode)HttpRuntime.Cache["SomeKeyName"];
if (temp == null)
{
temp = BuildSiteMap();
HttpRuntime.Cache.Insert("SomeKeyName", temp, null, DateTime.Now.AddHours(1), Cache.NoSlidingExpiration);
}
return temp;
}
}