news 2026/6/10 13:52:48

医院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/29 12:15:01

强脑20亿融资加码具身智能脑机融合研发,镜识人形机器人运动速度登顶,特斯拉推Optimus V3即将亮相,北京CES2026定档全球首个具身智能展

强脑科技完成20亿元融资,加码具身智能脑机融合研发国内脑机接口与具身智能融合领域龙头强脑科技披露,已完成20亿元大额融资,本轮融资由产业资本与地方国资联合加持,融资完成后企业估值突破13亿美元,资金将重点投入智能…

作者头像 李华
网站建设 2026/6/3 4:14:27

从MOOG产能扩张解析2000亿市场投资机会:商业航天+人形机器人双轮驱动航天伺服行业爆发

摘要:本报告聚焦MOOG产能扩张背后的航天伺服行业机遇,解析航天伺服系统在火箭姿态控制、卫星调整及人形机器人关节/灵巧手的核心应用。受益于全球火箭发射次数与有效载荷增长、SpaceX百万卫星部署及人形机器人量产,电机、减速器、旋转变压器市…

作者头像 李华
网站建设 2026/6/9 21:39:12

深入浅出地理解 C# WPF 中的​属性

想要深入浅出地理解 C# WPF 中的​属性​,核心要区分「C# 语言本身的属性」和「WPF 特有的依赖属性 / 附加属性」,还要掌握 WPF 中属性的核心用法(数据绑定、样式、动画等)—— 这也是 WPF 数据驱动 UI 的基础。我会从​基础到进阶…

作者头像 李华
网站建设 2026/6/5 4:10:47

Wi-Fi EAP-TLS

从医疗设备接入医院网络的实际需求来看,Wi-Fi EAP-TLS 可以理解为一种为设备接入无线网络设计的、基于数字证书的“高级门禁系统”。 1. 它是什么? EAP-TLS 是一种网络接入认证协议。它的核心是“双向数字证书认证”。 生活例子:想象一下进…

作者头像 李华
网站建设 2026/6/10 2:39:11

mTLS是什么

1. 它是什么 mTLS,即双向传输层安全协议,可以理解为一种“双方互相检查身份证”的通信安全机制。我们熟悉的普通TLS(如访问HTTPS网站)就像去一个重要场所,门卫只检查访客的证件(客户端验证服务器&#xff…

作者头像 李华