zoukankan      html  css  js  c++  java
  • SharePoint 2013 如何获取当前站点对应的“应用目录”中的“适用于SharePoint的应用程序”列表

    一开始我用的是以下方法,根据遍历当前站点下的Web应用程序(Web Application)中所有的网站集(Site Collection),查找模板为“APPCATALOG”的网站集,然后在它的根站点下查找功能标识为“0AC11793-9C2F-4CAC-8F22-33F93FAC18F2”的列表。

    这个列表就是“应用目录”下的“适用于SharePoint应用”列表。

    public static SPList GetCorporateCatalog(SPWeb web) {
        //SPSite site = GetSiteByWebTemplateId(18, current.Site.WebApplication);
        SPSite site = GetSiteByWebTemplate("APPCATALOG", web.Site.WebApplication);
        SPList list = GetListByTemplateFeatureId("0AC11793-9C2F-4CAC-8F22-33F93FAC18F2", site.RootWeb);
        return list;
    }
    
    public static SPList GetListByTemplateFeatureId(string templateFeatureId, SPWeb web) {
        foreach (SPList list in web.Lists) {
            if (string.Equals(list.TemplateFeatureId.ToString(), templateFeatureId, StringComparison.OrdinalIgnoreCase)) {
                return list;
            }
        }
        return null;
    }
    
    public static SPSite GetSiteByWebTemplateId(int webTemplateId, SPWebApplication webApplication) {
        foreach (SPSite site in webApplication.Sites) {
            if (site.RootWeb.WebTemplateId == webTemplateId) {
                return site;
            }
        }
        return null;
    }
    
    public static SPSite GetSiteByWebTemplate(string webTemplate, SPWebApplication webApplication) {
        foreach (SPSite site in webApplication.Sites) {
            if (string.Equals(site.RootWeb.WebTemplate, webTemplate, StringComparison.OrdinalIgnoreCase)) {
                return site;
            }
        }
        return null;
    }
    

    o(╯□╰)o 可是在审阅代码时,同事说这个方法效率太低。于是我猜想肯定有某个地方存储“应用目录”及“适用于SharePoint的应用程序”的标识。于是有了如下的方法: 

    static readonly Guid CorporateCuratedGallerySettingsFeatureID = new Guid("F8BEA737-255E-4758-AB82-E34BB46F5828");
    
    public static SPList GetCorporateCatalog(SPWeb web) {
        SPFeature settingsFeature = web.Site.WebApplication.Features[CorporateCuratedGallerySettingsFeatureID];
        Guid hostSiteId = new Guid(settingsFeature.Properties["__AppCatSiteId"].Value);
        Guid hostListId = new Guid(settingsFeature.Properties["__AppCatListId"].Value);
        using (SPSite hostSite = new SPSite(hostSiteId))
        using (SPWeb hostWeb = hostSite.RootWeb) {
            SPList corporateCatalog = hostWeb.Lists[hostListId];
            return corporateCatalog;
        }
    }
    

    原来在Web应用程序中有个名称为“CorporateCuratedGallerySettings”的功能(Feature),标识(ID)为“F8BEA737-255E-4758-AB82-E34BB46F5828”。它有两个属性:“__AppCatSiteId”,“__AppCatListId”,分别存储的是“应用目录”的标识(网站集ID)和“适用于SharePoint应用”的标识(列表ID)。

    O(∩_∩)O~~ 如果你能看懂并且会用到的话,就拿去玩吧。

    参阅:

    Sharepoint 2013: Existing Features GUID

  • 相关阅读:
    MFC Document/View 3
    MFC Document/View 2
    c++基本类型&&&c++string与c风格字符串的相互转化
    C++不同变量所在内存&&new malloc的区别
    C# 操作Excel 复选框
    prepareStatement与Statement的区别
    Oracle查询用户所有表、字段等信息
    同样的用户和密码,PL/SQL可以正常登录,C#程序却出现 ORA-1017 用户名/口令无效
    javascript原生态的同步异步请求实现
    SQL 数据库是否安全
  • 原文地址:https://www.cnblogs.com/windbell/p/HowTo_Get_CorporateCatalog.html
Copyright © 2011-2022 走看看