将 ONLYOFFICE 文档编辑器与 С# 群件平台集成

在本文中,我们会向您展示 ONLYOFFICE 文档编辑器与其自有的协作平台集成

ONLYOFFICE 是一款开源办公套件包括文本文档、电子表格和演示文稿编辑器这款套件支持用户通过文档编辑组件扩展第三方 web 应用的功能可直接应用的界面使用。在之前的几篇文章中,我们向您展示了如何实现这种集成请参考 Node.js  Python 示例)。

在本文中,我们向您展示一个真实的集成案例 ONLYOFFICE 文档编辑器与自协作平台集成

ONLYOFFICE Groups

ONLYOFFICE Groups社区服务器)是一个免费开源协作系统,使用 C# 编写根据 GNU GPL v3.0 分发包括文档和项目管理CRM电子邮件聚合器、日历、用户数据库、博客、论坛、投票、维基和即时通讯工具

ONLYOFFICE Groups 是完整的自托管解决方案的一部分支持用户在自己的服务器上部署功能齐备私人网络办公室。它免费的社区版和企业版企业版具备更多系统管理选项和增强的安全工具,适合更大团队使用

集成清单

如要将 ONLYOFFICE 文档编辑器与协作平台无缝集成所需的最重要权限清单如下

1添加定制代码

2匿名访问权限,用于下载和保存文件这意味着我们的编辑器仅在服务器端与协作平台通信,不涉及客户端的任何用户授权数据(浏览器 cookie

3添加界面按钮

4与协作平台模块(DMSCRM、项目、邮件)集成

5打开一个新页面用于执行脚本添加编辑器

6能够指定文档服务器连接设置

我们看看如何根据这份清单来实施集成

1添加代码

由于 ONLYOFFICE 编辑器是所有 ONLYOFFICE 解决方案的中心元在我们的协作系统中嵌入编辑功能在开始就是开工作的主要部分

此外,ONLYOFFICE 支持用户在社区服务器中添加自定义模块(如自己的 CRM 系统),为添加的模块创建 APIGitHub 有相关示例项目

2匿名访问

我们实施了一个回调处理程序,处理从 ONLYOFFICE 文档服务器到协作平台(即 DMS)的请求。它们之间直接交互不需要浏览器 cookie 等用户验证数据相反,它基于 JWT 技术,使用请求签名验证

文档服务器使用其配置文件中所谓的“密钥” JWT 添加到请求中。之后 DMS 会检查 JWT 密钥是否与其配置中的密钥一致。只有签名验证成功,回调处理程序才会执行请求的操作

如下 JWT 验证请求的处理过程

public class FileHandler : IHttpAsyncHandler
{public override void OnProcessRequest(HttpContext context){using (var receiveStream = context.Request.InputStream)using (var readStream = new StreamReader(receiveStream)){//request bodyvar body = readStream.ReadToEnd();//request datavar data = JToken.Parse(body);var callbackData = data.ToObject<CallbackData>();//request tokenvar jwtString = JsonWebToken.Decode(callbackData.Token, Config.JwtSecret);var jwtData = JObject.Parse(jwtString);if (jwtData == null){throw new ArgumentException("Document Service request token is incorrect");}//request data from JWTcallbackData = jwtData.ToObject<CallbackData>();result = ProcessData(callbackData);context.Response.Write(result ?? "{\"error\":0}");}}...
}

响应应该是

{”error”:0}

根据请求的状态,特定的操作被执行

public string ProcessData(CallbackData callbackData)
{switch (callbackData.Status){case NotFound:case Closed:FileTracker.Remove(callbackData.key);break;case Editing:ProcessEdit(callbackData);break;case MustSave:case Corrupted:return ProcessSave(callbackData);}return null;
}

3添加按钮

最重要的两个操作一定是打开查看和编辑相应是“预览”“编辑”按钮)。我们在界面中实施其他操作按钮则可支持用户执行以下操作

  • 移动
  • 复制
  • 下载可以选择所需的格式
  • 重命名
  • 删除
  • 查看文档的版本历史
  • 设置文件访问权限,包括共享设置为门户网站用户生成链接、阻止/解除阻止文档以及通过电子邮件发送文档。通过电子邮件发送文档是通过与邮件模块集成实现请参考下文)。

4与模块集成

除按钮外,还有一些操作需要文档服务器与其他服务或模块交互。例如,我们通过转换服务在文档管理的几个阶段转换文件,如用户上传、打开或下载文档时。但需要注意的是,因为 Office Open XML 是我们的核心格式,DOCXXLSX  PPTX 文件是会被直接处理,而其他文件格式都会被转换为 OOXML这样做是为了加速文件处理,提互操作性

用户不仅可以在文件管理系统中处理文档我们在之前一篇文章中有详细介绍),可以在 CRM、项目和邮件中进行

 CRM 模块中,用户可以:

  • 将文档附加到 CRM 和案
  • CRM 中直接创建新文档、工作表和演示文稿同样适用于商机和案例
  • 打开编辑或下载附件文档

用户可以从 CSV 文件将联系人批量导入 CRM,也可以将客户数据库导出为 CSV 文件

 “项目”模块中,我们为文档、电子表格和演示文稿建立了一个单独的文件夹(项目文档

用户可以将文档附到项目任务和讨论中可以直接在“项目”模块中创建新文件用户在管理附件文件时,可以对其进行编辑、下载或删除操作

“邮件”模块中,我们是这样实现集成的:除了将本地驱动器中的文档、电子表格和演示文稿附加到邮件之外,用户还可以存储在“文档”模块中的文件添加为附件如果文件大小限制,建议用户发送时使用所需文档链接

在这种情况下,文件链接会插入邮件正文在发送邮件之前,用户需要为所有链接指向的附件文件设置访问权限之后收件人点击邮件中的链接时基于指定的访问权限在线查看器或编辑器中打开文档

ONLYOFFICE 用户收到有文档附件的邮件时,可以

  • 下载附件
  • 在浏览器中查看文件
  • 打开文档、电子表格或演示文稿进行编辑(在这种情况下,如果格式不是 OOXML系统会自动将其转换为 .docx/.xlsx/.pptx 格式,并将其保存到“文档”中)
  • 将文件保存到“文档”,会选择所需的文件

用户可通过“邮件”设置“文档”模块选择任意文件夹电子邮件信息中的所有件都会被自动保存在这个文件夹中

此外,在“CRM”“项目”模块中,我们可以通过 ONLYOFFICE 文档生成工具文档生成器生成报告通过这款工具您无需实际运行文档处理编辑器即可生成文档。它还支持开发人员使用模板自动生成文档,或将数据库中的数据插入文档

5用编辑器打开页面

使用编辑器打开新页面时,会生成初始化配置发送至编辑器的主要参数包括定义文件类型的参数、界面语言 (editorConfig.lang = "en-US")以及每个用户的权限列表,也就是说,我们会检查用户是否拥有相应的权限:包括打开和编辑文执行其他操作表评下载、重命名文件等):

var config = {"document":{"fileType":"docx","info":{"author":"Me","created":"3\/29\/2019 10:06 PM","folder":"My Documents","sharingSettings":[{"permissions":"Full Access","user":"Me"}]},"key":"kouNPg1","permissions":{"changeHistory":true,"comment":true,"download":true,"edit":true,"fillForms":true,"print":true,"rename":true,"review":true},"title":"ONLYOFFICE Sample Document.docx","url":"https:\/\/demo.onlyoffice.com\/demo.docx"},"documentType":"text","editorConfig":{"callbackUrl":"https:\/\/demo.onlyoffice.com\/filehandler.ashx","lang":"en-US","mode":"edit","user":{"id":"9acf7169b737","name":"John Smith"}},"type":"desktop"
}

6连接设置

用户可以基于解决方案指定或不指定文档服务器连接设置

在我们自己托管的 ONLYOFFICE 云服务中,连接设置对用户隐藏,由我们在服务器配置中进行设置

ONLYOFFICE 服务器解决方案的用户可以指定安装 ONLYOFFICE 编辑器的服务器地址。门户管理员可在“设置”页面的“集成”板块进行相关设置

ONLYOFFICE 文档和社区服务器通常会安装在同一台机器上。在这种情况下,您的网络配置可能不允许它们之间使用公共地址收发请求。因此,需要另外两个字段(如上方截图所示)来指定 ONLYOFFICE 文档服务器地址,以便从社区服务器发出和接收内部请

管理员保存设置时,门户和编辑器之间的交互检查,以确保连接正确

如要详细了解 ONLYOFFICE 文档编辑器如何与其他服务集成,请参阅 API 文档

如果您想尝试将 ONLYOFFICE 文档编辑器与协作平台结合使用,并查看其集成情况,您可以在私人服务器上部署 ONLYOFFICE工作区即刻开始免费试用

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/171350.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# Onnx LSTR 基于Transformer的端到端实时车道线检测

目录 效果 模型信息 项目 代码 下载 效果 模型信息 lstr_360x640.onnx Inputs ------------------------- name&#xff1a;input_rgb tensor&#xff1a;Float[1, 3, 360, 640] name&#xff1a;input_mask tensor&#xff1a;Float[1, 1, 360, 640] -----------------…

开发vue3 UI组件库,并且发布到NPM

目录 1.创建vue3工程 2.创建package文件 3.编写组件&#xff0c;并且导出 4.编写package.json 5.npm账号注册登录并发布 6.从npm安装使用 7.注意事项 1.创建vue3工程 &#xff08;1&#xff09;初始化Vue项目 cnpm create vite &#xff08;2&#xff09;进入文件夹…

计算机基础知识50

数据的增删改查(insert update delete select) # 用户列表的展示&#xff1a; # 把数据表中得用户数据都给查询出来展示在页面上 1. 查询 from app01 import models models.UserInfo.objects.all() # 查询所有的字段信息和数据 resmodels.UserInfo.objects.first() # 查询…

sass 生成辅助色

背景 一个按钮往往有 4 个状态。 默认状态hover鼠标按下禁用状态 为了表示这 4 个状态&#xff0c;需要设置 4 个颜色来提示用户。 按钮类型一般有 5 个&#xff1a; 以 primary 类型按钮为例&#xff0c;设置它不同状态下的颜色&#xff1a; <button class"btn…

ros2_control的简单应用

文章目录 简介插件实现函数介绍代码 调用原理局限性 简介 在利用moveit_setup_assistant配置我们自己机械手后&#xff0c;当运行demo.launch.py时&#xff0c;会实例化一个moveit对象以及一个基于ros2_control的、虚拟的控制对象&#xff0c;从而可以实现一个完整的控制闭环。…

Rust 中的引用与借用

目录 1、引用与借用 1.1 可变引用 1.2 悬垂引用 1.3 引用的规则 2、slice 类型 2.1 字符串字面量其实就是一个slice 2.2 总结 1、引用与借用 在之前我们将String 类型的值返回给调用函数&#xff0c;这样会导致这个String会被移动到函数中&#xff0c;这样在原来的作用域…

【PC】开发者日志:竞技比赛验证系统强化

各位玩家大家好&#xff01;欢迎收看本期开发者日志。 在11月1日发布的第26赛季第2轮更新公告中&#xff0c;我们提到了有关强化比赛验证系统的内容。想必各位玩家一定会对我们加强验证系统的背景和意图感到好奇&#xff0c;为此我们想通过今天这篇反作弊开发者日志来向大家更详…

考研分享第1期 | 末9生物跨专业考研北京大学电子信息404分经验分享

全文概览 一、个人信息 二、关于考研的经验分享 三、最后的小Tips 一、个人信息 姓名&#xff1a;Jackson 本科院校&#xff1a;某末流985生物专业 报考院校&#xff1a;北京大学电子信息专业 择校意向&#xff1a;北航计算机、人大高瓴、复旦软院、清华大学深研院、北…

初认识vue,v-for,v-if,v-bind,v-model,v-html等指令

vue 一.vue3介绍 1.为什么data是函数而不是对象? 因为vue是组件开发,组件会多次复用,data如果是对象,多次复用是共享,必须函数返回一个新的对象 1. 官网初识 Vue (发音为 /vjuː/&#xff0c;类似 view) 是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS …

相机以及其它传感器传感器

深度相机点云质量对比 比较点云质量时需要注意的点&#xff1a; 1.对特殊材质、颜色的检测效果&#xff1a;透明塑料、金属、毛玻璃、高反光物体&#xff08;镜子、水坑&#xff09;、吸光物体&#xff08;黑色物体&#xff09;。 2.特殊环境&#xff1a;雨、雪、雾、明暗交替位…

打开word文档报错,提示HRESULT 0x80004005 位置: 部分: /word/comments.xml,行: 0,列: 0

某用户遇到这样一个奇怪的问题&#xff0c;就是回复完word的批注后&#xff0c;保存文档再打开就会报错&#xff0c;提示很抱歉&#xff0c;无法打开XXX&#xff0c;因为内容有问题。&#xff0c;详细信息提示HRESULT 0x80004005 位置: 部分: /word/comments.xml,行: 0,列: 0 c…

Rust-使用dotenvy加载和使用环境变量

系统的开发&#xff0c;测试和部署离不开环境变量&#xff0c;今天分享在Rust的系统开发中&#xff0c;使用dotenvy来读取和使用环境变量。 安装 cargo add dotenvy dotenv_codegen 加载环境变量 use dotenvy::dotenv;fn main() {dotenv().expect(".env不存在");…