sharepoint - 使用 PnPjs 和 .pdfConversionUrl 在 Sharepoint Online 中将 PPTX 导出为 PDF
问题描述
我们正在通过PnPjs框架和使用Sharepoint App插件与 Sharepoint Online 的文档库进行交互(我们目前无法使用 Graph API)
我们的插件可以完全控制我们的网站:
<AppPermissionRequests AllowAppOnlyPolicy="true">
<AppPermissionRequest Scope="http://sharepoint/content/sitecollection/web" Right="FullControl" />
</AppPermissionRequests>
我们几乎可以执行我们想要的所有操作 - 创建/删除文件夹、添加文件、复制文件等。我们坚持的一件事是将已上传到 Sharepoint 的 .pptx 文件导出为 .pdf 文件,从代码。
以下是我如何从文档库列表中检索 .pdfConversionUrl 以制定对 Microsoft 媒体转换服务的请求:
let options: RenderListDataOptions = RenderListDataOptions.EnableMediaTAUrls | RenderListDataOptions.ContextInfo | RenderListDataOptions.ListData | RenderListDataOptions.ListSchema;
const viewXml: string = `
<View Scope='RecursiveAll'>
<Query>
<Where>
<In>
<FieldRef Name='ID' />
<Values>
<Value Type='Counter'>{{OUR SP DOCUMENTS LIST ID}}</Value>
</Values>
</In>
</Where>
</Query>
<RowLimit>1</RowLimit>
</View>`;
const listStream = await sp.web.lists.getById({{OUR SP DOCUMENTS LIST ID}}).renderListDataAsStream({ RenderOptions: options, ViewXml: viewXml });
/*
* response contains this property:
* '.pdfConversionUrl': '{.mediaBaseUrl}/transform/pdf?provider=spo&inputFormat={.fileType}&cs={.callerStack}&docid={.spItemUrl}&{.driveAccessToken}'
* mediaBaseUrl, callerStack and driveAccessToken values are also included
*/
const pdfTransformURL = `${listStream.ListSchema['.mediaBaseUrl']}/transform/pdf?provider=spo&inputFormat=pptx&cs=${listStream.ListSchema['.callerStack']}&docid={{LINK TO THE SP PPTX FILE}}&${listStream.ListSchema['.driveAccessToken']}`;
console.log(pdfTransformURL);
这是生成的 URL:
https://northcentralus1-mediap.svc.ms/transform/pdf?provider=spo&inputFormat=pptx&cs={{OUR SP CALLER STACK}}&docid={{LINK TO OUR SP PPTX FILE}}&access_token={{OUR ACCESS TOKEN}}
当我们向该 URL 发出 GET 请求时,响应将包含 PDF 文件流,然后我们可以将其上传到 Sharepoint。 PnP 团队在此 youtube 视频中概述了该过程
但是,当我通过 node-fetch 或直接在浏览器中向该 URL 发出 GET 请求时,我收到以下错误消息:
{
"error":
{
"code":"generalException",
"message":"Exception: The remote server returned an error: (403) Forbidden. Access+denied.+Before+opening+files+in+this+location%2c+you+must+first+browse+to+the+web+site+and+select+the+option+to+login+automatically.",
"innererror":{"code":"Web_403Forbidden"}
}
}
我们用谷歌搜索,发现我们需要在 SP 管理面板中启用“允许不使用现代身份验证的应用程序”选项。我们这样做了,但我们仍然收到相同的错误消息。
如果那里的任何人以前尝试过此操作,请告诉我们如何解决此错误。谢谢!
解决方案
发现我的问题 - 我的 CAML 查询错误。应该是这样的:
const viewXml: string = `
<View Scope='RecursiveAll'>
<Query>
<Where>
<In>
<FieldRef Name='ID' />
<Values>
<Value Type='Counter'>{{Document ID, NOT List Id}}</Value>
</Values>
</In>
</Where>
</Query>
<RowLimit>1</RowLimit>
</View>`;
然后,使用 .spItemUrl 作为 ListData.Row 元素内部响应的一部分
希望这可以帮助某人
推荐阅读
- tensorflow - 从源安装 TensorFlow:找不到结果 /tmp/tensorflow_pkg
- c# - ABP cookie过期时间问题
- django - 如何使用 ChannelNameRouter 在 Worker 和 Websocket(Django 和 Channels2.x)之间进行通信?
- r - Display vector in R with a defined viewport
- text-extraction - pdftotext 获取字体信息(字体系列、样式、大小)
- java - 将数据直接从浏览器发送到 Java 桌面应用程序
- mysql - MySQL 绑定错误。错误 1452
- angular - 如何将 Three.js 加载器导入 Angular 6 项目
- javascript - addEventListener if else 条件不起作用
- html - flex-grow automatic margin for the first element