sharepoint 显示网站的基本架构

本文介绍了一种使用C#遍历SharePoint网站结构的方法,包括主网站、子网站、列表及文件夹的绑定过程。通过递归方式,能够详细展示整个SharePoint站点的组织结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Configuration;
using Microsoft.SharePoint;

namespace WebStructure
{
    public partial class _Default : System.Web.UI.Page
    {
        private string strWebUrl = ConfigurationManager.AppSettings["WebUrl"];
        protected void Page_Load(object sender, EventArgs e)
        {
            BindSite();
        }
        /// <summary>
        /// 绑定Site(主Web)
        /// </summary>
        private void BindSite()
        {
            using (SPWeb sPWeb = new SPSite(strWebUrl).OpenWeb())
            {
                TreeNode tn = new TreeNode();
                tn.Text = sPWeb.Title;
                BindLists(tn, sPWeb);// 绑定列表
                BindChildWebs(tn, sPWeb);// 绑定子Webs
                tvwStructure.Nodes.Add(tn);
                tvwStructure.CollapseAll();
            }
        }
        /// <summary>
        /// 绑定子Webs
        /// </summary>
        /// <param name="parentNode"></param>
        /// <param name="parentSPWeb"></param>
        private void BindChildWebs(TreeNode parentNode, SPWeb parentSPWeb)
        {
            SPWebCollection sPWebCollection = parentSPWeb.Webs;
            foreach (SPWeb sPWeb in sPWebCollection)
            {
                TreeNode tn = new TreeNode();
                tn.Text = sPWeb.Title;
                BindLists(tn, sPWeb);// 绑定列表
                BindChildWebs(tn, sPWeb);//递归绑定子Webs
                parentNode.ChildNodes.Add(tn);
            }
        }
        /// <summary>
        /// 绑定Lists
        /// </summary>
        /// <param name="parentNode"></param>
        /// <param name="parentSPWeb"></param>
        private void BindLists(TreeNode parentNode, SPWeb parentSPWeb)
        {
            SPListCollection sPListCollection = parentSPWeb.Lists;
            foreach (SPList sPList in sPListCollection)
            {
                TreeNode tn = new TreeNode();
                tn.Text = sPList.Title + "(" + sPList.BaseTemplate + ")[" + sPList.ItemCount + "]";
                BindFolder(tn, sPList);//绑定一级Folders
                parentNode.ChildNodes.Add(tn);
            }
        }
        /// <summary>
        /// 绑定一级Folders
        /// </summary>
        /// <param name="tn"></param>
        /// <param name="parentWebId"></param>
        /// <param name="parentSPList"></param>
        private void BindFolder(TreeNode parentNode, SPList parentSPList)
        {
            SPFolderCollection sPFolderCollection = parentSPList.RootFolder.SubFolders;
            foreach (SPFolder sPFolder in sPFolderCollection)
            {
                TreeNode tn = new TreeNode();
                tn.Text = sPFolder.Name;
                BindChildFolder(tn, sPFolder);//绑定子Folders
                parentNode.ChildNodes.Add(tn);
            }
        }
        /// <summary>
        /// 绑定子Folders
        /// </summary>
        /// <param name="parentNode"></param>
        /// <param name="parentFolder"></param>
        private void BindChildFolder(TreeNode parentNode, SPFolder parentSPFolder)
        {
            SPFolderCollection sPFolderCollection = parentSPFolder.SubFolders;
            foreach (SPFolder sPFolder in sPFolderCollection)
            {
                TreeNode tn = new TreeNode();
                tn.Text = sPFolder.Name;
                BindChildFolder(tn, sPFolder);//递归绑定子Folders
                parentNode.ChildNodes.Add(tn);
            }
        }
    }
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值