0

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

使用管理员用户,我可以在 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 服务 - 不工作!错误:拒绝访问。

那么,当我可以创建网站集但只有内容数据库创建不进行时,为什么会收到拒绝访问错误?

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

4

1 回答 1

0

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

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

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

于 2015-03-17T15:34:09.693 回答