Создание карты сайта Sharepoint/MOSS
-
22-07-2019 - |
Вопрос
Я пытаюсь создать карту сайта для моего сайта публикации MOSS. У меня есть два подхода, но, похоже, я застрял на обоих.
Мой первый подход — использовать PortalSiteMapProvider, который уже создан и хорошо кэширован...
PublishingWeb rootWeb = PublishingWeb.GetPublishingWeb(SPContext.Current.Site.RootWeb);
//Get the URL of the default page in the web
string defaultPageUrl = rootWeb.DefaultPage.ServerRelativeUrl;
PortalListItemSiteMapNode webNode = (PortalListItemSiteMapNode)PortalSiteMapProvider.CurrentNavSiteMapProviderNoEncode.FindSiteMapNode(defaultPageUrl);
HttpContext.Current.Response.Output.WriteLine("Top Level: " + webNode.Title.ToString() + "<br />");
//iterate through each one of the pages and subsites
foreach (SiteMapNode smnTopLevelItem in webNode.ParentNode.ChildNodes)
{
HttpContext.Current.Response.Output.WriteLine(smnTopLevelItem.Title.ToString() + "<br />");
//if the current sitemap has children, create a submenu for it
if (smnTopLevelItem.HasChildNodes)
{
foreach (SiteMapNode smnChildItem in smnTopLevelItem.ChildNodes)
{
HttpContext.Current.Response.Output.WriteLine(smnChildItem.Title.ToString() + "<br />");
}
}
}
HttpContext.Current.Response.End();
но, похоже, это возвращает все в семействе сайтов (например.списки, опросы).Я хочу показать только веб-сайты Sharepoint.
Мой другой подход заключался в использовании этого фрагмента кода.
SPSite siteCollection = new SPSite("http://example.org");
SPWebCollection sites = siteCollection.AllWebs;
foreach (SPWeb site in sites)
{
Console.WriteLine(site.Title.ToString() + " " + site.ServerRelativeUrl.ToString());
}
И это идеально, если не считать проблемы возврата всех веб-сайтов в виде плоского списка.
В идеале я хочу иметь возможность добавлять отступы для отображения дочерних веб-сайтов.
Решение 3
спасибо всем за ответы, вот что я придумал
public ListSiteMap()
{
PortalSiteMapProvider portalProvider1 = PortalSiteMapProvider.WebSiteMapProvider;
portalProvider1.DynamicChildLimit = 0;
portalProvider1.EncodeOutput = true;
SPWeb web = SPContext.Current.Site.RootWeb;
PortalSiteMapNode webNode = (PortalSiteMapNode)portalProvider1.FindSiteMapNode(web.ServerRelativeUrl);
if (webNode == null || webNode.Type != NodeTypes.Area) return;
Console.WriteLine(webNode.Title.ToString() + " - " + webNode.Description.ToString());
// get the child nodes (sub sites)
ProcessSubWeb(webNode);
}
private void ProcessSubWeb(PortalSiteMapNode webNode)
{
foreach (PortalSiteMapNode childNode in webNode.ChildNodes)
{
Console.WriteLine(childNode.Title.ToString() + " - " + childNode.Description.ToString());
//if the current web has children, call method again
if (childNode.HasChildNodes)
{
ProcessSubWeb(childNode);
}
}
}
Я нашел, что эти статьи помогли
http://blogs.mosshosting.com/archive /tags/SharePoint%20Object%20Model/default.aspx р>
http://www.hezser.de/blog/archive /tags/SPQuery/default.aspx р>
Другие советы
Обычно использовать объектную модель для рекурсии — плохая идея.Это очень медленно и ресурсоемко. PortalSiteMapProvider
предварительно кэшируется для вас и может просмотреть всю структуру сайта за миллисекунды.
Что касается вашего вопроса о SPSite.AllWebs
, это свойство возвращает плоский список всех веб-сайтов.Вот для чего это нужно.Если вам нужен список только немедленный дочерние сети, используйте SPSite.RootWeb.Webs
свойство.Рекурсия по каждому SPWeb
в .Webs
имущество и позвонить им .Webs
свойство, в свою очередь, чтобы получить представление в виде дерева.
Кроме того, при работе с объектной моделью обязательно УТИЛИЗАЦИЯ КАЖДОГО ВЕБ-САЙТА И САЙТА.Если вы этого не сделаете, это вызовет эпические проблемы.Это включает в себя уничтожение каждой сети в .Webs
коллекцию, даже если вы к ней не прикасались.
Редактировать:
Чтобы PortalSiteMapProvider возвращал только веб-сайты, установите его IncludePages
собственность false
.
Вы пытались проверить тип каждого узла в цикле foreach, используя свойство PortalSiteMapNode.Type и отображая только узлы типа NodeTypes.Area?
Вы можете использовать этот инструмент:
http: // realworldsa. blogspot.com/2010/12/new-tool-for-sharepoint-2007-and-2010.html р>