onlyoffice 使用记录(前端开发角度)

前端和Web文档生成器服务器交互

对于与 Web 文档生成器服务的交互,使用 POST 请求。 请求参数在请求正文中以 JSON 格式输入。 请求被发送到 https://documentserver/docbuilder 地址,其中 documentserver 是安装了 ONLYOFFICE 文档服务器的服务器的名称,例如服务部署在http://10.1.32.41:4200,那请求的地址就是http://10.1.32.41:4200/docbuilder。本地可以使用postman来模拟请求,请求的body为:

javascript 复制代码
{
    "async": false,
    "url": "https://test.com/pan/downloads/6c9c5394d2cde725fdd0b3684ab5d4da.docbuilder"
}

其中url表示docbuilder脚本的绝对地址。

发送post请求后,正常会返回

javascript 复制代码
{
    "key": "bld_efebb2986f314678",
    "urls": {
        "Api.pptx": "http://10.1.54.16:8000/cache/files/data/bld_efebb2986f314678/output/Api.pptx/Api.pptx?md5=Jct57-pmrac2U1PRvz-XjQ&expires=1726037649&shardkey=10.1.58.34new.pptx11725938741963&filename=Api.pptx"
    },
   "end": true

其中key就是我们要在config.document.key中配置的key值,注意,要把key的前缀bld_去掉,只保留efebb2986f314678,否则报错:An error has occurred while opening the file.

config如下:

typescript 复制代码
    config: IConfig = {
        document: {
            fileType: "pptx",
            key: "efebb2986f314678", //key值需要把前缀bld_去掉
            title: "test.pptx",
            url: "http://10.1.54.16:8000/cache/files/data/bld_efebb2986f314678/output/Api.pptx/Api.pptx?md5=Jct57-pmrac2U1PRvz-XjQ&expires=1726037649&shardkey=10.1.58.34new.pptx11725938741963&filename=Api.pptx"
        },
        height: "600px",
        documentType: "slide",
        editorConfig: {
            callbackUrl: "http://10.1.54.16:8000/dummyCallback"
        },
    }
相关推荐
让我上个超影吧5 分钟前
基于SpringBoot和Vue实现CAS单点登录
前端·vue.js·spring boot
军军君0124 分钟前
Three.js基础功能学习五:雾与渲染目标
开发语言·前端·javascript·学习·3d·前端框架·three
程序员爱钓鱼26 分钟前
Node.js 编程实战:RESTful API 设计
前端·后端·node.js
程序员爱钓鱼28 分钟前
Node.js 编程实战:GraphQL 简介与实战
前端·后端·node.js
罗技1231 小时前
Easysearch 集群监控实战(下):线程池、索引、查询、段合并性能指标详解
前端·javascript·算法
XiaoYu20021 小时前
第3章 Nest.js拦截器
前端·ai编程·nestjs
千寻girling1 小时前
面试官 : “ 说一下 Map 和 WeakMap 的区别 ? ”
前端·javascript·面试
2501_924064111 小时前
2025年主流Web自动化测试工具功能与适用场景对比
前端·测试工具·自动化
IT_陈寒1 小时前
Vite 5 实战:7个鲜为人知的配置技巧让构建速度提升200%
前端·人工智能·后端
gg159357284601 小时前
JavaScript 核心基础
前端·javascript·vue.js