sql -ASP.NET站点地图

Translate

有没有人有创造经验基于SQL的ASP.NET网站地图提供商?

我有默认的XML文件web.sitemap与我的菜单正常工作SiteMapPath控件,但我需要一种让网站用户动态创建和修改页面的方法。

我需要将页面查看权限纳入标准ASP.NET会员制。

This question and all comments follow the "Attribution Required."

所有的回答

Translate

来自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缓存很酷,但是如果您不想每次加载菜单时都要去数据库(以检查依赖项是否已更改)并且菜单不经常更改,那么为什么不使用它呢?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;
    }
}
来源