场景:我有一个 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)连接以某种方式正常工作。