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

Programmatically create content database in C# (SP 2013)

目标是拥有一个 Web 用户界面,其中包含使用新内容数据库创建新网站集的选项。

通过管理员用户,我可以在 CA 中手动创建新的内容数据库。我还可以在此内容数据库中创建新网站集。

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

实验: 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 服务 - 不工作!错误:拒绝访问。

那么,为什么当我可以创建网站集但无法创建内容数据库时出现访问被拒绝的错误?

最后我执行了 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 中问过同样的问题。

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

如果“http://sp2013”的应用程序池用户没有农场管理员权限,您将无法使用事件接收器创建内容数据库(可能由于这个原因,您的事件接收器出现拒绝访问错误并且您的网络服务代码)。问题是将农场管理员权限授予应用程序池或服务用户,这是一个非常糟糕的主意。

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