WSS3SDK之:如何获取网站和站点集对象

您可以返回一个网站集下的所有网站,一个网站下的所有位于第一层的子网站,当前网站下所有的子站点和列表,或是某个SharePoint Web应用程序下面的所有网站集,正如下面的例子所示。

利用SPSite类的AllWebs属性,您可以返回一个网站集下的所有网站,包括顶级网站和所有子网站。下面的例子显示了在当前的网站集下的所有网站和列表的标题。
VB
复制代码
Dim mySite As SPSite = SPContext.Current.Site
Dim subSites As SPWebCollection = mySite.AllWebs
Dim i As Integer

For i = 0 To subSites.Count - 1
    
Dim lists As SPListCollection = subSites(i).Lists
    
Dim j As Integer

    
For j = 0 To lists.Count - 1
        Response.Write(SPEncode.HtmlEncode(subSites(i).Title) 
            
& " :: " _ & SPEncode.HtmlEncode(lists(j).Title) & "<BR>")
    
Next j
Next i
复制代码

C#
复制代码
SPSite mySite = SPContext.Current.Site;
SPWebCollection subSites 
= mySite.AllWebs;

for (int i=0;i<subSites.Count;i++)
{
    SPListCollection lists 
= subSites[i].Lists;

    
for (int j=0;j<lists.Count;j++)
    {
        Response.Write(SPEncode.HtmlEncode(subSites[i].Title) 
            
+ " :: " + SPEncode.HtmlEncode(lists[j].Title) + "<BR>");
    }
}
复制代码
上面的例子需要引用Microsoft.SharePoint和Microsoft.SharePoint.Utilities命名空间。
如果我们要返回某网站下的所有第一层子站点的清单,可以使用SPWeb类的Webs属性。下面是示例代码:
VB
复制代码
Dim mySite As SPWeb = SPContext.Current.Web
Dim sites As SPWebCollection = mySite.Webs
Dim subSite As SPWeb

For Each subSite In  sites
    Response.Write(SPEncode.HtmlEncode(subSite.Title) 
& "<BR>")
Next subSite
复制代码
C#
复制代码
SPWeb mySite = SPContext.Current.Web;
SPWebCollection sites 
= mySite.Webs;

foreach (SPWeb subSite in sites)
{
    Response.Write(SPEncode.HtmlEncode(subSite.Title) 
+ "<BR>");
}
复制代码
上面的例子同样需要引用Microsoft.SharePoint和Microsoft.SharePoint.Utilities这两个命名空间。
下面的例子用for语句代替了foreach,处理相同的工作:
VB
复制代码
Dim mySite As SPWeb = SPContext.Current.Web
Dim sites As SPWebCollection = mySite.Webs
Dim i As Integer

For i = 0 To sites.Count - 1
    
Dim lists As SPListCollection = sites(i).Lists
    
Dim j As Integer

    
For j = 0 To lists.Count - 1
        Response.Write(sites(i).Url 
& " :: " 
            
& SPEncode.HtmlEncode(lists(j).Title) & "<BR>")
    
Next j
Next i
复制代码
C#
复制代码
SPWeb mySite = SPContext.Current.Web;
SPWebCollection sites 
= mySite.Webs;

for (int i=0;i<sites.Count;i++)
{
    SPListCollection lists 
= sites[i].Lists;

    
for (int j=0;j<lists.Count;j++)
    {
        Response.Write(sites[i].Url 
+ " :: " 
            
+ SPEncode.HtmlEncode(lists[j].Title) + "<BR>");
    }
}
复制代码
这端代码同样需要引用Microsoft.SharePoint和Microsoft.SharePoint.Utilities这两个命名空间。
接下来的例子将显示当前网站下的所有子网站和列表,同时显示各列表中的条目数量。通过嵌套foreach语句来遍历所有的网站和列表集合。
VB
复制代码
Dim mySite As SPWeb = SPContext.Current.Web
Dim sites As SPWebCollection = mySite.Webs
Dim subSite As SPWeb

For Each subSite In  sites
    Response.Write(
"<B>" & SPEncode.HtmlEncode(subSite.Title) & "</B>" 
        
& "<BR>")

    
Dim lists As SPListCollection = subSite.Lists
    
Dim list As SPList

    
For Each list In  lists
        Response.Write(SPEncode.HtmlEncode(list.Title) 
& " :: " 
           
& list.ItemCount & "<BR>")
    
Next list
Next subSite 
复制代码
C#
复制代码
SPWeb mySite = SPContext.Current.Web;
SPWebCollection sites 
= mySite.Webs;

foreach (SPWeb subSite in sites)
{
    Response.Write(
"<B>" + SPEncode.HtmlEncode(subSite.Title) + "</B>" 
        
+ "<BR>");

    SPListCollection lists 
= subSite.Lists;

    
foreach (SPList list in lists)
    {
        Response.Write(SPEncode.HtmlEncode(list.Title) 
            
+ " :: " + list.ItemCount + "<BR>");
    }
}
复制代码
同样,本例也需要引用那2个命名空间。
如果要返回某SharePoint Web应用程序下所有的网站集的集合,可以使用Microsoft.SharePoint.Administration.SPWebApplication类的Sites属性。通过Microsoft.SharePoint.SPContent类的属性可以返回当前的Web应用程序。下面的样例显示了当前Web应用下所有网站集的URL地址。
VB
复制代码
Dim webApplication As SPWebApplication = SPContext.Current.Site.WebApplication
Dim siteCollections As SPSiteCollection = webApplication.Sites
Dim siteCollection As SPSite

For Each siteCollection In siteCollections
   Response.Write(siteCollection.Url 
+ "<BR>")
Next siteCollection
复制代码

C#
复制代码
SPWebApplication webApplication = SPContext.Current.Site.WebApplication;
SPSiteCollection siteCollections 
= webApplication.Sites;

foreach (SPSite siteCollection in siteCollections)
{
   Response.Write(siteCollection.Url 
+ "<BR>");
}
复制代码

上面的例子需要引用Microsoft.SharePoint,Microsoft.SharePoint.Administration,以及Microsoft.SharePoint.Utilities命名空间,并假设位于一个包含label控件的.aspx页面中。
posted @   Sunmoonfire  阅读(945)  评论(2编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示