当前位置: 首页 > news >正文

汽车制造PLM系统TinyMCE导入CATIA图纸出现图层错位怎么办?

天津XX软件公司 - 客户单位CMS系统新闻模块Word导入功能升级项目实施记录

一、项目背景与需求确认

  1. 客户单位需求

    • 在CMS系统后台新闻模块中新增Word文档一键导入功能,需自动上传图片至服务器并保留原始样式(字体、颜色、表格、段落格式等)。
    • 信创环境支持
      • 操作系统:Windows、macOS、统信UOS、中标麒麟、银河麒麟、龙芯(LoongArch架构)。
      • 数据库:达梦DM8、人大金仓KingbaseES V8。
      • 开发框架:前端Vue2-cli + TinyMCE编辑器,后端SpringBoot 2.7.x。
    • 服务要求:提供7×24小时在线技术支持,故障响应时间≤1小时。
  2. 项目目标

    • 完成功能开发并通过国产化环境兼容性测试。
    • 交付可维护的代码、部署文档及培训材料。

二、技术选型与产品评估

1. 候选方案分析
方案可行性评估
TinyMCE官方插件优势:原生支持样式保留,社区活跃;
风险:国产化环境需二次开发图片上传逻辑。
Apache POI + OpenXML优势:完全控制Word解析过程;
风险:开发周期长,样式保留需手动实现。
商业中间件(如WPS开放平台)优势:功能完善,支持信创认证;
风险:成本高,需对接第三方API。
开源库(Mammoth.js)优势:轻量级;
风险:样式兼容性差,仅支持基础格式。
开源插件(WordPaster)优势:与原文档保持1:1样式,完全开放产品源代码,支持信创国产化环境,
风险:需要安装插件。
|

决策:采用TinyMCE 5.10 + 自定义SpringBoot后端服务,平衡开发效率与国产化适配需求。

2. 技术栈确认
  • 前端
    • Vue2-cli + TinyMCE 5.10(企业版试用许可,确保技术支持)。
    • 集成tinymce-wordimport插件(开源版扩展)。
  • 后端
    • SpringBoot 2.7.12 + Apache POI 5.2.3(解析Word文档)。
    • HttpClient 4.5.13(图片上传至国产化存储)。
  • 信创适配
    • 数据库驱动:达梦JDBC 8.1.1.193、人大金仓JDBC 8.6.0。
    • 跨平台构建:使用OpenJDK 11(支持LoongArch架构)。

三、开发实施过程

1. 前端开发(Vue2 + TinyMCE)
  • 步骤1:集成TinyMCE编辑器并配置自定义按钮。

    // main.jsimport'tinymce/plugins/paste';import'tinymce/plugins/importcss';import'./plugins/wordimport';// 自定义插件tinymce.init({selector:'#news-editor',plugins:'paste importcss wordimport',toolbar:'wordimport',setup:(editor)=>{editor.ui.registry.addButton('wordimport',{text:'导入Word',onAction:()=>{constinput=document.createElement('input');input.type='file';input.accept='.docx';input.onchange=async(e)=>{constfile=e.target.files[0];consthtml=awaitconvertWordToHtml(file);// 调用后端APIeditor.setContent(html);};input.click();}});}});
  • 步骤2:实现Word内容预处理。

    • 使用docx-preview库在前端渲染Word大纲,供用户确认样式。
2. 后端开发(SpringBoot)
  • 步骤1:文件解析服务。

    // WordParserService.javapublicStringparseWordToHtml(MultipartFilefile)throwsIOException{XWPFDocumentdoc=newXWPFDocument(file.getInputStream());Stringhtml=newXHTMLConverter().convert(doc,null,null);// Apache POI扩展// 提取图片并上传Patternpattern=Pattern.compile("src=\"data:image/(.*?);base64,(.*?)\"");Matchermatcher=pattern.matcher(html);while(matcher.find()){Stringbase64=matcher.group(2);StringimageUrl=uploadImageToServer(base64,matcher.group(1));html=html.replace(matcher.group(0),"src=\""+imageUrl+"\"");}returnhtml;}
  • 步骤2:国产化存储适配。

    • 图片上传至华为云OBS(统信版SDK),支持SSL加密传输。
    • 达梦数据库连接池配置:
      spring:datasource:url:jdbc:dm://192.168.1.100:5236/CMS_DBdriver-class-name:dm.jdbc.driver.DmDriverhikari:maximum-pool-size:10
3. 信创环境兼容性处理
  • 操作系统适配
    • 中标麒麟/银河麒麟:使用-Dfile.encoding=UTF-8启动JVM。
    • 龙芯平台:通过-march=loongarch64编译Native库。
  • 数据库优化
    • 达梦SQL调优:为图片URL字段添加索引,避免全表扫描。
    • 人大金仓事务隔离级别设置为READ COMMITTED

四、测试与验证

  1. 功能测试
    • 用例1:导入含10张图片的50页Word文档,验证图片上传成功率100%。
    • 用例2:检查复杂表格(合并单元格、跨页)样式保留完整性。
  2. 信创兼容性测试
    • 统信UOS + 达梦:通过自动化脚本验证CRUD操作响应时间≤2秒。
    • 龙芯平台:使用JProfiler监控内存占用,确保无内存泄漏。
  3. 安全测试
    • 防止XXE攻击:禁用Apache POI的DTD加载。
    • 文件类型限制:通过Magic Number校验文件真实性。

五、技术支持与运维方案

  1. 7×24小时服务保障
    • 与TinyMCE签订企业版支持协议,提供专属技术支持通道。
    • 部署Zabbix监控系统,实时告警数据库连接池耗尽等故障。
  2. 知识转移
    • 为客户单位提供《国产化环境部署手册》《API接口规范》。
    • 开展2次线上培训,覆盖编辑器高级功能与故障排查。

六、项目交付成果

  1. 功能模块
    • 新闻编辑器新增“Word导入”按钮,支持一键上传与样式保留。
    • 图片自动压缩(长边≤1920px)以节省存储空间。
  2. 文档清单
    • 《信创环境适配报告》《测试用例库》《运维应急预案》。
  3. 验收标准
    • 通过等保2.0三级测评,符合《信息安全技术—政务信息共享数据安全技术要求》。

项目负责人签字:_________________
客户单位代表签字:_________________
日期:2025年XX月XX日

备注:本项目代码已开源至Gitee信创专区,供客户单位二次开发参考。

复制插件

安装jquery

npm install jquery

在组件中引入

// 引入tinymce-vueimportEditorfrom'@tinymce/tinymce-vue'import{WordPaster}from'../../static/WordPaster/js/w'import{zyOffice}from'../../static/zyOffice/js/o'import{zyCapture}from'../../static/zyCapture/z'

添加工具栏

//添加导入excel工具栏按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor).importExcel()}varregister$1=function(editor){editor.ui.registry.addButton('excelimport',{text:'',tooltip:'导入Excel文档',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('excelimport',{text:'',tooltip:'导入Excel文档',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('excelimport',function(editor){Buttons.register(editor);});}Plugin();}());//添加word转图片工具栏按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().importWordToImg()}varregister$1=function(editor){editor.ui.registry.addButton('importwordtoimg',{text:'',tooltip:'Word转图片',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('importwordtoimg',{text:'',tooltip:'Word转图片',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('importwordtoimg',function(editor){Buttons.register(editor);});}Plugin();}());//添加粘贴网络图片工具栏按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().UploadNetImg()}varregister$1=function(editor){editor.ui.registry.addButton('netpaster',{text:'',tooltip:'网络图片一键上传',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('netpaster',{text:'',tooltip:'网络图片一键上传',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('netpaster',function(editor){Buttons.register(editor);});}Plugin();}());//添加导入PDF按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().ImportPDF()}varregister$1=function(editor){editor.ui.registry.addButton('pdfimport',{text:'',tooltip:'导入pdf文档',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('pdfimport',{text:'',tooltip:'导入pdf文档',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('pdfimport',function(editor){Buttons.register(editor);});}Plugin();}());//添加导入PPT按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().importPPT()}varregister$1=function(editor){editor.ui.registry.addButton('pptimport',{text:'',tooltip:'导入PowerPoint文档',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('pptimport',{text:'',tooltip:'导入PowerPoint文档',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('pptimport',function(editor){Buttons.register(editor);});}Plugin();}());//添加导入WORD按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor).importWord()}varregister$1=function(editor){editor.ui.registry.addButton('wordimport',{text:'',tooltip:'导入Word文档',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('wordimport',{text:'',tooltip:'导入Word文档',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('wordimport',function(editor){Buttons.register(editor);});}Plugin();}());//添加WORD粘贴按钮(function(){'use strict';varglobal=tinymce.util.Tools.resolve('tinymce.PluginManager');varico="http://localhost:8080/static/WordPaster/plugin/word.png"functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor).PasteManual()}varregister$1=function(editor){editor.ui.registry.addButton('wordpaster',{text:'',tooltip:'Word一键粘贴',onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem('wordpaster',{text:'',tooltip:'Word一键粘贴',onAction:function(){selectLocalImages(editor)}});};varButtons={register:register$1};functionPlugin(){global.add('wordpaster',function(editor){Buttons.register(editor);});}Plugin();}());

在线代码:

添加插件

// 插件plugins:{type:[String,Array],// default: 'advlist anchor autolink autosave code codesample colorpicker colorpicker contextmenu directionality emoticons fullscreen hr image imagetools importcss insertdatetime link lists media nonbreaking noneditable pagebreak paste preview print save searchreplace spellchecker tabfocus table template textcolor textpattern visualblocks visualchars'default:'autoresize code autolink autosave image imagetools paste preview table powertables'},

点击查看在线代码

初始化组件

// 初始化WordPaster.getInstance({// 上传接口:http://www.ncmem.com/doc/view.aspx?id=d88b60a2b0204af1ba62fa66288203edPostUrl:'http://localhost:8891/upload.aspx',// 为图片地址增加域名:http://www.ncmem.com/doc/view.aspx?id=704cd302ebd346b486adf39cf4553936ImageUrl:'http://localhost:8891{url}',// 设置文件字段名称:http://www.ncmem.com/doc/view.aspx?id=c3ad06c2ae31454cb418ceb2b8da7c45FileFieldName:'file',// 提取图片地址:http://www.ncmem.com/doc/view.aspx?id=07e3f323d22d4571ad213441ab8530d1ImageMatch:''})

在页面中引入组件

功能演示

编辑器

在编辑器中增加功能按钮

导入Word文档,支持doc,docx

导入Excel文档,支持xls,xlsx

粘贴Word

一键粘贴Word内容,自动上传Word中的图片,保留文字样式。

Word转图片

一键导入Word文件,并将Word文件转换成图片上传到服务器中。

导入PDF

一键导入PDF文件,并将PDF转换成图片上传到服务器中。

导入PPT

一键导入PPT文件,并将PPT转换成图片上传到服务器中。

上传网络图片

一键自动上传网络图片。

下载示例

点击下载完整示例

http://www.jsqmd.com/news/345363/

相关文章:

  • 2026年评价高的阿里1688运营/1688运营热门榜单推荐 - 行业平台推荐
  • 从斑马鱼到机器鱼:机器人实验重塑神经行为研究
  • 2026年如何选购户外亮化灯具正规厂家,靠谱品牌全攻略 - mypinpai
  • 互联网医院TinyMCE6处理电子病历截图出现色差怎么解决?
  • 教育平台TinyMCE4处理Word艺术字粘贴变成乱码如何修复?
  • 2026精准学数跃靠谱不,梳理全国精准学数跃加盟排名情况 - 工业品牌热点
  • 梳理京津冀地区专业离婚律师事务所,老牌离婚律所选购指南 - 工业品网
  • 央企应用中如何处理大文件断点续传的方案总结?
  • 2026年资深离婚律所推荐,北京元甲律所服务贴心 - myqiye
  • 教育行业如何实现大文件批量上传的方案总结?
  • 2026年热门的农业养殖项目/金头蜈蚣农业养殖项目项目优选指南 - 行业平台推荐
  • 总结户外亮化灯具制造厂,云南口碑好的品牌排名 - mypinpai
  • 2026年苏州靠谱婚房装修公司推荐,性价比高的品牌排行 - 工业推荐榜
  • 深圳昊客网络科技海外GEO优化推广科普:AI时代出海企业的流量密码 - 深圳昊客网络
  • 武汉新华电脑学校编程plc培训怎么样,费用怎么收 - 工业品牌热点
  • 2026年上海、浙江等地好用的纯化水设备批量定制品牌推荐 - 工业设备
  • 2026寒假放假通知SVG动画制作工具与指南 公众号文章必备组件合集 - peipei33
  • 雷达原理实验教学系统定制化开发哪里能做?核心厂家与能力解析 - 品牌推荐大师
  • VMWare下Windows XP的声音问题
  • 聊聊权威的AI自习室,精准数跃性价比高值得推荐 - 工业推荐榜
  • 2026年昆明知名的别墅全案设计品牌企业排名,哪家性价比高? - 工业设备
  • TP框架 之vue3简易论坛系统
  • java--线程安全问题
  • 好写作AI:专治“对着空白文档发呆”,你的灵感急救呼吸机!
  • 全网最全8个降AIGC网站,千笔AI助你高效降AI率
  • 真心不骗你!继续教育论文神器 —— 千笔ai写作
  • 导师推荐!千笔,顶尖配置的AI论文写作软件
  • 格式总出错?AI论文工具 千笔 VS 文途AI,本科生写作更轻松!
  • Jenkins节点拉取代码报错场景及解决方案全解析
  • chrome://settings/content/all