0

场景:我有一个 Angular SPA 和一个 SharePoint 2013,安装在不同的服务器上。我想在我的 SPA 中使用 SharePoint 讨论板,这意味着我想使用我的自定义 UI 在 SharePoint 讨论板上执行 CRU(D) 操作。

通过一些变通方法,我已经使用 SP REST API 实现了这个目标,但不幸的是,由于 REST API 不允许为讨论板设置一些参数(特别是 ParentID),我真的不能以令人满意的方式使用 REST API。为了能够通过 REST API 工作,我必须更改 SharePoint Server 的 IIS 中的配置以重写标头并允许跨域调用。此外,我将作为选项传递给来自上下文信息的 http 调用摘要。正如我所说,通信有效,我可以创建新的讨论或回复,但这些都是格式错误的,因为 API 本身不提供我需要的方法,而只是一些解决方法来发布不太好看的消息讨论板(例如线程完全丢失)。

使用 JSOM,我正在这样做(我简化了一点):

createReply() {
    let clientContext = new SP.ClientContext("otherserver.sharepoint.com");
    let list = clientContext.get_web().get_lists().getByTitle("myDiscussionBoardName");
    let discussionItem = list.getItemById(parentTopicId); //eg. parentTopicId === 10
    let properties = {'Body': 'My Message'};
    let messageItem = SP.Utilities.Utility.createNewDiscussionReply(clientContext, discussionItem);
    for (var propName in properties) {
        messageItem.set_item(propName, properties[propName])
    }
    messageItem.update();

    clientContext.executeQueryAsync(() => 
       { console.log("Gotcha!", messageItem); },
       (error: any) => { console.log('Request failed', error); });
  }

但不幸的是,我收到了 401 错误。我的理解也是我不需要提供摘要,因为 JSOM 应该自己处理它,但我不确定这一点,也不知道如何在 JSOM 调用中提供摘要。

老实说,这条消息是我查明真相的最后希望。我实际上已经在计划使用不同的解决方案,但我不敢相信不存在解决方案,特别是因为使用本地代理(sp-rest-proxy,如果您基于SP)连接以某种方式正常工作。

4

1 回答 1

0

检查下面的链接,我也只是从我们的代码中放了一个例子

http://sharepointsanjay.blogspot.com/2016/05/how-to-refresh-request-digest-token.html
var headers = {
            "Accept": "application/json; odata=verbose",
            "Content-Type": "application/json; odata=verbose",
            "X-RequestDigest": document.getElementById("__REQUESTDIGEST").value,
            "X-HTTP-Method": "MERGE",
            "If-Match": "*"
        };

        return $http({
            headers: headers,
            method: "POST",
            url: url,
            data: JSON.stringify(data)
        }).then(complete, failed);
于 2021-01-28T20:16:37.253 回答