news 2026/5/8 3:43:09

医院HIS系统富文本编辑器是否兼容WPS文档的图文转存?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
医院HIS系统富文本编辑器是否兼容WPS文档的图文转存?

杭州XX软件公司项目开发记录:后台管理系统富文本增强功能开发

(Word粘贴/导入、微信公众号内容粘贴、图片二进制存储)

一、需求分析与技术选型
  1. 核心需求

    • 粘贴功能:支持从Word/微信公众号复制内容到UEditor,保留样式(字体、颜色、表格等),图片自动上传至二进制存储服务器(后期迁移至对象存储)。
    • 导入功能:支持Word/Excel/PPT/PDF导入,保留图片和样式,生成可编辑的HTML内容。
    • 技术约束:前端Vue2+UEditor,后端PHP,MySQL,内网私有部署,拒绝Base64图片。
  2. 技术挑战

    • UEditor默认对Word粘贴支持有限,需扩展pasteUtils.jsserver.js
    • 图片需通过后端接口上传至二进制存储,返回URL供编辑器渲染。
    • 文档导入需解析.docx/.pdf等格式,推荐使用Apache POI(Java)或PHP库(如PhpOffice),但需兼容PHP环境。
  3. 选型决策

    • 粘贴功能:基于UEditor的pasteFilter扩展,结合自定义PHP接口处理图片上传。
    • 导入功能:采用PhpOffice套件(PHPOffice/PhpWord、PhpSpreadsheet、PhpPresentation)解析文档,TCPDFImagick处理PDF图片提取。
    • 图片存储:开发PHP二进制上传接口,支持分块上传和断点续传(兼容大文件)。
二、开发过程记录

1. 环境准备

  • 部署测试环境:CentOS 7 + Nginx + PHP 7.4 + MySQL 5.7。
  • 安装依赖:composer require phpoffice/phpword phpoffice/phpspreadsheet
  • 配置UEditor:启用wordImage插件,修改ueditor.config.js中的imageUrl指向后端上传接口。

2. 粘贴功能开发

  • 前端修改
    // 覆盖UEditor默认粘贴行为,拦截Word内容UE.registerUI('wordpaste',function(editor){editor.addListener('beforePaste',function(type,html){if(isWordContent(html)){// 提取图片并上传constimages=extractWordImages(html);returnuploadImagesAsync(images).then(urls=>{returnreplaceImagesWithUrls(html,urls);});}});});
  • 后端接口(PHP):
    // upload.php$file=$_FILES['upfile'];$binaryData=file_get_contents($file['tmp_name']);$storagePath='/uploads/'.uniqid().'.png';file_put_contents($_SERVER['DOCUMENT_ROOT'].$storagePath,$binaryData);echojson_encode(['url'=>$storagePath]);

3. 导入功能开发

  • Word/Excel/PPT解析
    // import_docx.phpusePhpOffice\PhpWord\IOFactory;$phpWord=IOFactory::load('input.docx');$html='';foreach($phpWord->getSections()as$section){foreach($section->getElementList()as$element){if(method_exists($element,'toHtml')){$html.=$element->toHtml();}}}// 提取图片并上传(同粘贴逻辑)
  • PDF处理
    使用Imagick将PDF转为图片,再插入HTML:
    $imagick=newImagick('input.pdf[0]');$imagick->setImageFormat('png');file_put_contents('/tmp/pdf_image.png',$imagick);

4. 图片存储优化

  • 二进制存储:直接写入文件系统,数据库记录路径和MD5校验值。
  • 对象存储兼容:预留接口,未来可替换为阿里云OSS SDK上传:
    functionuploadToOss($binaryData){$ossClient=newOssClient($key,$secret,$endpoint);return$ossClient->putObject('bucket','path/file.png',$binaryData);}
三、问题与解决方案
  1. UEditor粘贴样式丢失

    • 原因:默认过滤了``等标签。
    • 解决:修改ueditor.parse.js,在filterRules中保留font-familycolor等属性。
  2. 大文件上传超时

    • 解决:分块上传+临时文件合并,Nginx配置client_max_body_size 100M
  3. PDF表格解析错乱

    • 解决:改用pdftohtml工具转换后手动清洗HTML结构。
四、测试与部署
  1. 测试用例

    • 粘贴含复杂样式的Word文档,验证图片上传和样式保留。
    • 导入100MB的PPT,检查内存泄漏和进度反馈。
  2. 私有部署文档

    • 提供docker-compose.yml快速部署二进制存储服务。
    • 编写PHP配置脚本,自动初始化MySQL表结构(存储图片元数据)。
五、后续规划
  1. 对象存储迁移:开发迁移工具,将现有二进制文件批量同步至阿里云OSS。
  2. 性能优化:对导入的HTML进行压缩,减少前端渲染压力。
  3. 安全性:增加图片上传白名单,防止恶意文件注入。

开发人员:张三
日期:2023年XX月XX日
备注:代码已提交至GitLab,分支feature/ueditor-enhance,待PM评审后合并。

复制插件目录

引入插件文件

UEditor 1.4.3.3示例

注意:不要重复引入jquery,如果您的项目已经引入了jq,则不用再引入jq-1.4

在工具栏中增加插件按钮

//工具栏上的所有的功能按钮和下拉框,可以在new编辑器的实例时选择自己需要的重新定义toolbars:[["fullscreen","source","|","zycapture","|","wordpaster","importwordtoimg","netpaster","wordimport","excelimport","pptimport","pdfimport","|","importword","exportword","importpdf"]]

初始化控件

varpos=window.location.href.lastIndexOf("/");varapi=[window.location.href.substr(0,pos+1),"asp/upload.asp"].join("");WordPaster.getInstance({//上传接口:http://www.ncmem.com/doc/view.aspx?id=d88b60a2b0204af1ba62fa66288203edPostUrl:api,//为图片地址增加域名:http://www.ncmem.com/doc/view.aspx?id=704cd302ebd346b486adf39cf4553936ImageUrl:"",//设置文件字段名称:http://www.ncmem.com/doc/view.aspx?id=c3ad06c2ae31454cb418ceb2b8da7c45FileFieldName:"file",//提取图片地址:http://www.ncmem.com/doc/view.aspx?id=07e3f323d22d4571ad213441ab8530d1ImageMatch:''});//加载控件

注意

如果接口字段名称不是file,请配置FileFieldName。ueditor接口中使用的upfile字段

点击查看详细教程

配置ImageMatch

匹配图片地址,如果服务器返回的是JSON则需要通过正则匹配

ImageMatch:'',

点击参考链接

配置ImageUrl

为图片地址增加域名,如果服务器返回的图片地址是相对路径,可通过此属性添加自定义域名。

ImageUrl:"",

点击查看详细教程

配置SESSION

如果接口有权限验证(登陆验证,SESSION验证),请配置COOKIE。或取消权限验证。
参考:http://www.ncmem.com/doc/view.aspx?id=8602DDBF62374D189725BF17367125F3

效果

编辑器界面

导入Word文档,支持doc,docx

导入Excel文档,支持xls,xlsx

粘贴Word

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

Word转图片

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

导入PDF

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

导入PPT

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

上传网络图片

下载示例

点击下载完整示例

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/8 3:43:09

纠结!信息学竞赛vs奥数,初高中党该怎么选?一篇讲透不踩坑

后台每天都能收到家长和同学的灵魂拷问:“孩子数学底子不错,选奥数还是信息学竞赛?”“两者哪个对强基、综评更有帮助?”“怕选错浪费时间精力,到底该怎么判断?”其实奥数和信息学竞赛,从来没有…

作者头像 李华
网站建设 2026/4/30 10:03:11

春节特供:项目管理人的“反内卷”自救指南

“凌晨2点改方案?跨部门扯皮到崩溃?年终总结写到怀疑人生? 当‘内卷’成为年关的‘职场诅咒’,项目管理人如何用DooTask破局? 3招反内卷指南:透明协作、智能排期、自动报告—— 把‘拼命模式’调成‘高效模…

作者头像 李华
网站建设 2026/5/8 0:06:23

Mac 扩展坞(Dock)总是跑到副屏?一个非常有效的解决方法记录

​ 在使用 Mac 外接显示器(扩展坞 / 副屏) 的过程中,很多人都会遇到一个让人非常抓狂的问题:Dock(程序坞)莫名其妙跑到副屏上了,而且怎么挪都不太对。 ​ 尤其是当你把 主屏 用来工作、而副屏只…

作者头像 李华
网站建设 2026/5/3 6:59:41

内网环境下,html5如何支持大文件的分块上传?

中石油旗下子公司大文件传输系统技术方案 一、项目背景与需求分析 作为中石油集团旗下专注于能源信息化领域的子公司,我司长期服务于政府及军工单位,在能源管理、安全生产等关键领域积累了丰富的行业经验。本次政府招投标项目提出的大文件传输需求具有…

作者头像 李华
网站建设 2026/4/30 5:09:36

2026必备!8个降AIGC工具千笔AI帮你降AI率

AI降重工具:论文降AIGC率的关键利器 随着人工智能技术的飞速发展,越来越多的学术研究和论文写作开始依赖AI工具。然而,AI生成的内容在查重系统中往往容易被识别为高AIGC率内容,影响论文的通过率。对于继续教育领域的学生和研究人…

作者头像 李华