Есть ли у кого-нибудь опыт создания поставщиков карты сайта ASP.NET на основе SQL?
У меня есть XML-файл web.sitemap по умолчанию, который правильно работает с элементами управления Menu и SiteMapPath, но мне понадобится способ для пользователей моего сайта динамически создавать и изменять страницы.
Мне также нужно привязать разрешения на просмотр страниц к стандартной системе членства ASP.NET.


Версия Джеффа Просиза из журнала MSDN работает неплохо, но у нее есть несколько недостатков:
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;
}
}