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

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第1张图片

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 body
            var body = readStream.ReadToEnd();

            //request data
            var data = JToken.Parse(body);
            var callbackData = data.ToObject();

            //request token
            var 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 JWT
            callbackData = jwtData.ToObject();
            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添加按钮

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

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第2张图片

4与模块集成

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

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

 CRM 模块中,用户可以:

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

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第3张图片

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

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第4张图片

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

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第5张图片

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

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

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第6张图片

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

将 ONLYOFFICE 文档编辑器与 С# 群件平台集成_第7张图片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 文档编辑器与 С# 群件平台集成_第8张图片

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

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

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

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

 

你可能感兴趣的:(编辑器,onlyoffice,api,开源)