TermSet Creation使用自定义Web服务在SharePoint 2013中提供错误

时间:2013-09-05 13:26:41

标签: web-services sharepoint-2013 csom

我正在尝试使用SharePoint 2013服务器中部署的自定义WCF Web服务在SharePoint 2013中创建新的术语集。我在下面写了代码来创建术语集。

SPSecurity.RunWithElevatedPrivileges(delegate()
            {
                using (Impersonator imp = new Impersonator("Username", "Domain", "Password"))
                {
                    using (SPSite site = new SPSite("http://server:8002/sites/site/"))
                    {
                        site.AllowUnsafeUpdates = true;
                        TaxonomySession session = new TaxonomySession(site);
                        TermStore termStore = session.TermStores["Managed Metadata Service"];
                        var termStoreAdmin = termStore.TermStoreAdministrators.Where(obj => obj.PrincipalName.Contains("domain\\username")).FirstOrDefault();

                        if (termStoreAdmin == null)
                            termStore.AddTermStoreAdministrator("domain\\username");

                        Group group = termStore.GetGroup(new Guid(groupGuid));
                        if (group != null && !string.IsNullOrEmpty(termSetName))
                        {
                            TermSet termset = group.TermSets.FirstOrDefault(obj => obj.Name.Equals(termSetName));
                            if (termset == null)
                            {
                                termset = group.CreateTermSet(termSetName);
                                termSetGuid = termset.Id.ToString();
                            }
                            SetupNavTermSet(termset, session, site.OpenWeb());
                        }
                        termStore.CommitAll();
                    }
                }
            });

我使用soap message从silverlight代码调用此方法。在调用此代码时,我在执行group.CreateTermSet(termSetName);行时遇到异常。

错误是:

Error Message :  Value cannot be null.
Source        : Microsoft.SharePoint
Error Details :     at Microsoft.SharePoint.Administration.Claims.SPClaimProviderManager.GetUserIdentifierEncodedClaim(IIdentity identity)
   at Microsoft.SharePoint.Taxonomy.Internal.CommonUtilities.GetCurrentUserName()
   at Microsoft.SharePoint.Taxonomy.TaxonomySession.get_CurrentUserName()
   at Microsoft.SharePoint.Taxonomy.Group.CreateTermSet(String name, Guid newTermSetId, Int32 lcid)
   at Microsoft.SharePoint.Taxonomy.Group.CreateTermSet(String name)
   at SplitVisionMetadataManagement.CustomManageMetaDataWCFService.<>c__DisplayClassc.<CreateTaxonomyTermSet>b__8()

有人有这个问题和解决方案吗?

1 个答案:

答案 0 :(得分:2)

我也遇到了同样的问题,并且发现Microsoft.SharePoint.Taxonomy.Internal.CommonUtilities.GetCurrentUserName()方法使用HttpContext.Current.User安全主体来获取用户名。

我在Windows窗体应用程序中使用类似的代码,因此HttpContext为空。我通过手动设置上下文和用户来解决了这个问题。

if (HttpContext.Current == null)  
{  
    HttpRequest request = new HttpRequest("", SiteURL, "");  
    HttpContext.Current = new HttpContext(request, new HttpResponse(TextWriter.Null));  
    HttpContext.Current.User = System.Threading.Thread.CurrentPrincipal;  
}  

SPSecurity.RunWithElevatedPrivileges(delegate()  
{  
    using (SPSite site = new SPSite(SiteURL))  
    {  
        using (SPWeb web = site.OpenWeb())  
        {  
            if (HttpContext.Current.Items["HttpHandlerSPWeb"] == null)  
                HttpContext.Current.Items["HttpHandlerSPWeb"] = web;  

            // Your SharePoint Term Creation code
        }
    }
});

在您的情况下,您似乎正在使用基于声明的身份验证,因此在返回名称时声明提供程序存在一些问题。您的HTTP上下文将是运行WCF的上下文。您可能需要在这些角度进一步调查。

以上知识可以帮助您进一步理解。