以C#编程创建内容数据库(SP 2013)

时间:2015-02-19 08:37:47

标签: c# sharepoint permissions sharepoint-2013 sitecollection

目标是拥有一个Web用户界面,可以选择使用新的内容数据库创建新的网站集。

使用admin用户,我可以在CA中手动创建新的内容数据库。我还可以在此内容数据库中创建新的网站集。

想法是创建一个事件接收器(C#)。如果用户将数据添加到表中,则执行上述操作。

实验: a)控制台应用程序 - 有效!

using (SPSite site = new SPSite("http://sp2013")) {
  using (SPWeb spWeb = site.OpenWeb()) {
      SPWebApplication elevatedWebApp = spWeb.Site.WebApplication;
        elevatedWebApp.ContentDatabases.Add("sp2013", "WSS_Content_80_" + DateTime.Now.ToString("yyyymmddhhMMss"), null, null, 10, 15, 0);
    }
}

b)事件接收器 - 仅创建网站集工作,创建内容数据库不起作用!错误:访问被拒绝。

c)Web服务 - 不起作用!错误:访问被拒绝。

那么,为什么我在创建网站集时会收到错误Access Denied,但是只创建内容数据库?

最后我执行了PS脚本 - 但这也行不通。

# AUTHOR: Paul Kotlyar
# CONTACT: unclepaul84@gmail.com
# DESCRIPTION: sets an option on content web service that allows updating of SP Administration objects such as SPJobDefinition from content web applications
function Set-RemoteAdministratorAccessDenied-False()
{
    # load sharepoint api libs
    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") > $null
    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Administration") > $null

  # get content web service
 $contentService = [Microsoft.SharePoint.Administration.SPWebService]::ContentService
  # turn off remote administration security
 $contentService.RemoteAdministratorAccessDenied = $false
  # update the web service
 $contentService.Update()
}

也许有人知道解决方案?

我在Stackexchange中问了同样的问题。

1 个答案:

答案 0 :(得分:0)

这是权限问题,但不适用于客户帐户。客户端用户无关紧要。问题是,对于内容数据库创建,您的代码需要服务器场管理员权限。但是,使用提升的权限运行代码是不够的,因为当您以这种方式执行代码时,SharePoint会模拟对应Web应用程序的应用程序池用户。

如果“http://sp2013”的应用池用户没有服务器管理员权限,则无法使用事件接收器创建内容数据库(可能因此您的事件接收器和Web服务存在“拒绝访问”错误码)。问题是给予应用程序池或服务用户农场管理员权限这是一个非常糟糕的主意。

我建议您将此解决方案实现为计时器作业。您可以创建SharePoint场解决方案,并创建计时器作业,因为通常使用场管理员帐户执行计时器作业。通过这种方式,您可以创建内容数据库。