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

银行内网系统如何确保Excel公式导入CKEditor的数据安全?

CMS企业官网项目 - 编辑器Word导入功能集成记录需求分析作为四川的一名PHP程序员最近接手的CMS企业官网项目客户提出了一个新需求在CKEditor 4编辑器中实现Word等文档的一键导入功能。具体要求包括支持Word/Excel/PPT/PDF文档导入支持微信公众号内容粘贴保留原始文档样式字体、字号、颜色、表格、公式等自动上传图片到阿里云OSS以插件形式扩展不影响现有功能预算控制在99元以内技术评估与选型现有技术栈前端Vue2 CLI CKEditor 4后端PHP (Zend Studio开发环境)数据库MySQL云存储阿里云OSS服务器阿里云ECS解决方案调研方案一CKEditor Paste from Word插件CKEditor官方提供了Paste from Word插件但有以下局限仅支持Word内容粘贴不支持完整文件导入样式保留有限复杂公式和图表可能丢失需要额外开发图片上传功能官方插件免费但功能有限方案二TinyMCE PowerPasteTinyMCE的PowerPaste插件功能强大但需要切换到TinyMCE编辑器商业授权超出预算约$200/年集成成本较高方案三CKEditor custom插件 Mammoth.js最终选择方案使用Mammoth.js (.docx转换)使用SheetJS (Excel处理)使用pdf.js (PDF处理)自定义CKEditor插件整合这些库优点完全开源零成本可定制性强保留现有编辑器不破坏现有功能开发实施1. 环境准备# 安装Mammoth.jsnpminstallmammoth# 安装SheetJSnpminstallxlsx# 安装pdf.jsnpminstallpdfjs-dist2. 创建CKEditor自定义插件在CKEditor插件目录创建wordimport插件plugins/wordimport/ ├── plugin.js ├── icons/ │ └── wordimport.png └── dialogs/ └── wordimport.js3. 插件核心代码 (plugin.js)CKEDITOR.plugins.add(wordimport,{icons:wordimport,init:function(editor){editor.addCommand(wordimport,newCKEDITOR.dialogCommand(wordimport));editor.ui.addButton(WordImport,{label:导入Office文档,command:wordimport,toolbar:insert});CKEDITOR.dialog.add(wordimport,this.pathdialogs/wordimport.js);// 处理粘贴事件editor.on(paste,function(evt){handlePasteEvent(evt,editor);});}});functionhandlePasteEvent(evt,editor){constclipboardDataevt.data.dataTransfer;if(clipboardData.getData(text/html)){// 处理从Word粘贴的内容cleanWordHTML(editor,clipboardData.getData(text/html));evt.cancel();}}asyncfunctioncleanWordHTML(editor,html){try{constcleanedHTMLawaitprocessWordHTML(html);editor.insertHtml(cleanedHTML);}catch(error){console.error(Error processing Word content:,error);editor.insertHtml(html);// 回退到原始内容}}4. 文档转换处理// 处理Word文档asyncfunctionhandleWordFile(file){constarrayBufferawaitfile.arrayBuffer();constresultawaitmammoth.convertToHtml({arrayBuffer:arrayBuffer});// 处理图片consthtmlWithImagesawaitprocessImages(result.value);returnhtmlWithImages;}// 处理Excel文档asyncfunctionhandleExcelFile(file){constarrayBufferawaitfile.arrayBuffer();constworkbookXLSX.read(arrayBuffer,{type:array});lethtml;constworksheetworkbook.Sheets[workbook.SheetNames[0]];constjsonDataXLSX.utils.sheet_to_json(worksheet,{header:1});jsonData.forEach(row{html;row.forEach(cell{html;});html;});html${cell || };returnhtml;}5. 图片上传处理// PHP端图片上传处理 (OSS)functionuploadImageToOSS($tempPath){require_onceoss-sdk-php/autoload.php;$accessKeyIdyour-access-key-id;$accessKeySecretyour-access-key-secret;$endpointyour-oss-endpoint;$bucketyour-bucket-name;$ossClientnewOssClient($accessKeyId,$accessKeySecret,$endpoint);$objectuploads/.uniqid()..jpg;$optionsarray();try{$ossClient-uploadFile($bucket,$object,$tempPath,$options);return$ossClient-signUrl($bucket,$object,3600);}catch(OssException$e){error_log(OSS Upload Error: .$e-getMessage());returnfalse;}}6. 前端与后端接口// Vue组件中调用methods:{asyncuploadDocument(file){constformDatanewFormData();formData.append(file,file);try{constresponseawaitaxios.post(/api/upload-document,formData,{headers:{Content-Type:multipart/form-data}});this.editorInstance.insertHtml(response.data.html);}catch(error){console.error(Upload failed:,error);}}}部署实施前端部署构建Vue项目npm run build将dist目录内容部署到阿里云ECS后端部署配置PHP环境支持文件上传设置阿里云OSS访问权限部署PHP接口文件数据库调整添加媒体资源记录表CREATETABLEmedia_resources(idint(11)NOTNULLAUTO_INCREMENT,oss_pathvarchar(255)NOTNULL,local_pathvarchar(255)DEFAULTNULL,mime_typevarchar(100)DEFAULTNULL,created_attimestampNOTNULLDEFAULTCURRENT_TIMESTAMP,PRIMARYKEY(id))ENGINEInnoDBDEFAULTCHARSETutf8mb4;成本控制开发成本使用开源库0元开发时间8小时按本地市场价约500元但属于项目范围调整服务器成本阿里云OSS存储费用预计0.01元/月小流量使用ECS资源消耗无额外成本总成本完全控制在99元预算内使用说明在编辑器工具栏点击导入Office文档按钮选择要导入的Word/Excel/PPT/PDF文件系统自动转换并插入到编辑器中从Word复制内容可直接粘贴保留样式从微信公众号复制的内容也会自动处理遇到的问题及解决方案Word公式支持问题问题MathType公式转换为图片时失真解决使用mammoth.js的自定义转换器处理公式Excel复杂表格样式丢失问题合并单元格和复杂样式无法保留解决添加自定义CSS类模拟原始样式图片上传超时问题大文件上传到OSS超时解决实现分块上传并添加进度指示项目总结通过集成开源库和自定义开发成功在预算内实现了客户需求。主要成果包括完整支持Office文档导入保留绝大多数原始样式和结构无缝图片上传到OSS微信公众号内容兼容处理非侵入式插件设计不影响现有功能客户测试反馈良好编辑效率提升显著特别是对频繁从Word和微信公众号复制内容的市场部门来说节省了大量排版时间。复制插件说明此教程以CKEditor4.x为例使用其他编辑器的查看对应教程。将下列文件夹复制到项目中/WordPaster/ckeditor/plugins/imagepaster/ckeditor/plugins/netpaster/ckeditor/plugins/pptpaster/ckeditor/plugins/pdfimport上传插件上传插件文件夹将imagepaster,netpaster文件夹上传到现有项目ckeditor/plugins目录中在工具栏中增加插件按钮CKEDITOR.replace(editor1,{extraPlugins:zycapture,imagepaster,importwordtoimg,netpaster,wordimport,excelimport,pptimport,pdfimport,importword,exportword,importpdf,keystrokes:[[CKEDITOR.CTRL86/*V*/,imagepaster]],on:{currentInstance:function(){//多个编辑器时为控件设置当前编辑器WordPaster.getInstance().SetEditor(CKEDITOR.currentInstance);window.zyCapture.setEditor(this);window.zyOffice.SetEditor(this);}},//https://ckeditor.com/docs/ckeditor4/latest/api/CKEDITOR_config.html#cfg-allowedContentallowedContent:true//不过滤样式});引用js初始化控件WordPaster.getInstance({//上传接口http://www.ncmem.com/doc/view.aspx?idd88b60a2b0204af1ba62fa66288203edPostUrl:api,//为图片地址增加域名http://www.ncmem.com/doc/view.aspx?id704cd302ebd346b486adf39cf4553936ImageUrl:,//设置文件字段名称http://www.ncmem.com/doc/view.aspx?idc3ad06c2ae31454cb418ceb2b8da7c45FileFieldName:file,//提取图片地址http://www.ncmem.com/doc/view.aspx?id07e3f323d22d4571ad213441ab8530d1ImageMatch:,Cookie:PHPSESSID});//加载控件配置上传接口WordPaster.getInstance({//上传接口http://www.ncmem.com/doc/view.aspx?idd88b60a2b0204af1ba62fa66288203edPostUrl:api,//为图片地址增加域名http://www.ncmem.com/doc/view.aspx?id704cd302ebd346b486adf39cf4553936ImageUrl:,//设置文件字段名称http://www.ncmem.com/doc/view.aspx?idc3ad06c2ae31454cb418ceb2b8da7c45FileFieldName:file,//提取图片地址http://www.ncmem.com/doc/view.aspx?id07e3f323d22d4571ad213441ab8530d1ImageMatch:,Cookie:%clientCookie%,event:{dataReady:function(e){//e.word,//e.imgs:tag1,tag2,tag3console.log(e.imgs)}}});//加载控件注意1.如果接口字段名称不是file请配置FileFieldName。ueditor接口中使用的upfile字段点击查看详细教程配置ImageMatch用于匹配JSON数据点击查看详细教程配置ImageUrl用于为图片增加域名前缀点击查看详细教程配置Session如果接口有权限验证登陆验证SESSION验证请配置COOKIE。或取消权限验证。参考点击查看详细教程说明1.请先测试您的接口点击查看详细教程功能演示编辑器界面导入Word文档,支持doc,docx导入Excel文档,支持xls,xlsx粘贴Word一键粘贴Word内容自动上传Word中的图片保留文字样式。Word转图片一键导入Word文件并将Word文件转换成图片上传到服务器中。导入PDF一键导入PDF文件并将PDF转换成图片上传到服务器中。导入PPT一键导入PPT文件并将PPT转换成图片上传到服务器中。上传网络图片一键自动上传网络图片自动下载远程服务器图片自动上传远程服务器图片下载示例点击下载完整示例

相关文章:

银行内网系统如何确保Excel公式导入CKEditor的数据安全?

CMS企业官网项目 - 编辑器Word导入功能集成记录 需求分析 作为四川的一名PHP程序员,最近接手的CMS企业官网项目客户提出了一个新需求:在CKEditor 4编辑器中实现Word等文档的一键导入功能。具体要求包括: 支持Word/Excel/PPT/PDF文档导入支…...

【Docker 27低代码集成权威指南】:20年DevOps专家亲授容器化低代码平台落地的5大避坑法则

第一章:Docker 27低代码平台容器集成全景认知 Docker 27 是一款面向企业级低代码开发场景深度优化的容器化运行时环境,其核心能力在于将可视化建模、组件编排与容器生命周期管理无缝融合。它并非 Docker CE 或 EE 的简单版本迭代,而是基于 Mo…...

工业容器安全红线清单,Docker 27新增device-cgroup-policy与seccomp-v2双锁机制解析(仅限首批通过IEC 62443-4-2认证的17家厂商内部共享)

第一章:工业容器安全红线清单的演进逻辑与合规基线工业容器安全红线清单并非静态文档,而是随OT/IT融合深度、攻击面扩展及监管框架升级持续演进的技术契约。其底层逻辑源于三重张力:实时性约束与隔离强度的平衡、遗留设备兼容性与零信任原则的…...

Codeforces评分预测神器Carrot:从API崩溃到社区自救的技术传奇

Codeforces评分预测神器Carrot:从API崩溃到社区自救的技术传奇 【免费下载链接】carrot A browser extension for Codeforces rating prediction 项目地址: https://gitcode.com/gh_mirrors/carrot1/carrot 想象一下这样的场景:你正在参加一场激烈…...

ACE-Step镜像详解:开箱即用的音乐创作神器

ACE-Step镜像详解:开箱即用的音乐创作神器 你有没有想过,自己也能像专业音乐人一样,用几句话就“召唤”出一段完整的音乐?不是简单的旋律片段,而是带有完整编曲、丰富配器,甚至能表达特定情绪的背景音乐。…...

LinkSwift网盘直链下载助手:一键解锁八大平台高速下载通道

LinkSwift网盘直链下载助手:一键解锁八大平台高速下载通道 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘 / …...

OpenBoardView:完全免费的.brd电路板查看终极方案

OpenBoardView:完全免费的.brd电路板查看终极方案 【免费下载链接】OpenBoardView View .brd files 项目地址: https://gitcode.com/gh_mirrors/op/OpenBoardView 还在为昂贵的电路板设计软件而烦恼吗?想要一款真正免费、跨平台、功能强大的.brd文…...

跨越物理边界:基于P2P虚拟局域网实现安全远程SSH办公

1. 为什么我们需要P2P虚拟局域网远程办公? 最近几年远程办公越来越普遍,但很多开发者都会遇到一个头疼的问题:怎么安全地连接到公司内网的服务器?传统做法要么需要公司开放公网端口(安全隐患大)&#xff0c…...

BuildRoot下RTL8822CE蓝牙模块驱动加载与固件路径排错指南

1. RTL8822CE蓝牙模块驱动加载问题排查 遇到RTL8822CE蓝牙模块驱动加载失败时,内核日志通常会显示"load firmware failed"错误。这个问题我遇到过多次,根本原因是系统找不到正确的固件文件。先别急着改代码,让我们从最基础的排查开…...

从零上手MIMIC-IV:给临床科研新手的保姆级数据表关联与查询避坑指南

从零上手MIMIC-IV:临床科研新手的数据库实战指南 第一次打开MIMIC-IV数据库时,面对上百张数据表和复杂的关联关系,大多数临床研究者都会感到无从下手。作为医疗领域最权威的公开数据库之一,MIMIC-IV包含了超过40万名患者的完整诊疗…...

抖音无水印下载神器:douyin-downloader 终极实战教程

抖音无水印下载神器:douyin-downloader 终极实战教程 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback suppor…...

逆向工程深度实践:Cyberpunk 2077存档编辑器的架构解析与高级应用

逆向工程深度实践:Cyberpunk 2077存档编辑器的架构解析与高级应用 【免费下载链接】CyberpunkSaveEditor A tool to edit Cyberpunk 2077 sav.dat files 项目地址: https://gitcode.com/gh_mirrors/cy/CyberpunkSaveEditor CyberpunkSaveEditor是一款基于逆向…...

Android Compose 应用中实现全局Dialog管理器的设计与实践

文章目录 前言一、传统 Dialog 实现的问题二、全局状态管理的实现1.CompositionLocal 介绍2.全局状态管理应用①. 定义 CompositionLocal②. 抽象基类设计③. 具体 Dialog 参数类型实现④. 全局 Dialog 组件 3.实现 DialogManager设计优势 4.实际应用①. 提供全局状态②. 使用③…...

除了防DDoS,阿里云CDN安全应急响应还能帮你搞定哪些“后门”和“暗链”?

阿里云CDN安全应急响应:从WebShell清理到攻击溯源的实战指南 当网站遭遇黑客入侵时,大多数运维团队的第一反应往往是检查服务器日志或防火墙规则,却常常忽略了CDN层可能存在的安全隐患。事实上,现代攻击者越来越倾向于利用CDN作为…...

终极指南:如何用免费开源CAD软件LitCAD快速上手二维绘图

终极指南:如何用免费开源CAD软件LitCAD快速上手二维绘图 【免费下载链接】LitCAD A very simple CAD developed by C#. 项目地址: https://gitcode.com/gh_mirrors/li/LitCAD LitCAD是一款基于C#开发的轻量级开源二维CAD绘图平台,为初学者和设计爱…...

Cadence APD and SiP ---手动增加泪滴快速寻找信号下void 设计参数设置(3)

摘要:本文详细介绍了Cadence Allegro/APD软件在PCB设计中的多项关键功能应用。主要内容包括:1)最小间距检查的参数设置与结果解析;2)材料库管理及基板材料的创建方法;3)铜皮排气孔设计的具体参数配置;4)设计参数的全面设置(显示、文本、走线规则等);5)信号走线与电…...

CocosCreator Graphics性能避坑指南:绘制复杂图表时,如何避免卡顿和内存泄漏?

CocosCreator Graphics性能优化实战:复杂图表绘制的高效解决方案 在数据可视化需求爆炸式增长的今天,CocosCreator的Graphics组件因其灵活的绘图能力成为开发者首选工具。但当面对动态更新的折线图、多系列柱状图等复杂场景时,未经优化的Grap…...

5分钟掌握Diff Checker:免费跨平台文本差异对比神器

5分钟掌握Diff Checker:免费跨平台文本差异对比神器 【免费下载链接】diff-checker Desktop application to compare text differences between two files (Windows, Mac, Linux) 项目地址: https://gitcode.com/gh_mirrors/di/diff-checker 还在为代码修改、…...

抖音下载器终极教程:3分钟学会免费批量下载视频素材

抖音下载器终极教程:3分钟学会免费批量下载视频素材 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support…...

狂人印奇入主阶跃星辰:从“技术理想”到“商业狂想”,一场AI独角兽的绝地反击

狂人印奇入主阶跃星辰:从“技术理想”到“商业狂想”,一场AI独角兽的绝地反击左手旷视,右手阶跃,印奇在AI 2.0时代布下一盘怎样的棋?前言 2026年,中国大模型赛道的竞争已进入白热化阶段。在“AI六小龙”中&…...

从被拒到接收:我的三篇SCI投稿血泪史与避坑指南(附完整时间线)

从被拒到接收:我的三篇SCI投稿血泪史与避坑指南(附完整时间线) 第一次投稿Physical Review Materials时,我像大多数科研新人一样充满期待。精心打磨三个月的论文,却在五天后收到冰冷的拒信——编辑甚至没有送审。那一刻…...

保姆级教程:在Ubuntu 18.04上从零搭建FAST_LIO_SAM(含GPS融合与回环检测配置)

从零搭建FAST_LIO_SAM:Ubuntu 18.04实战指南(含GPS融合与回环检测) 在机器人自主导航领域,激光惯性里程计(LIO)系统正成为环境感知的核心技术。本文将带您逐步完成FAST_LIO_SAM系统的完整部署,这…...

如何在英雄联盟国服中免费解锁所有皮肤:R3nzSkin完整指南

如何在英雄联盟国服中免费解锁所有皮肤:R3nzSkin完整指南 【免费下载链接】R3nzSkin-For-China-Server Skin changer for League of Legends (LOL) 项目地址: https://gitcode.com/gh_mirrors/r3/R3nzSkin-For-China-Server 你是否曾经羡慕其他玩家拥有炫酷的…...

终极指南:如何在Windows 10/11上完美修复ViPER4Windows音频增强工具

终极指南:如何在Windows 10/11上完美修复ViPER4Windows音频增强工具 【免费下载链接】ViPER4Windows-Patcher Patches for fix ViPER4Windows issues on Windows-10/11. 项目地址: https://gitcode.com/gh_mirrors/vi/ViPER4Windows-Patcher 厌倦了Windows 1…...

朱雀AIGC检测不过怎么办?2026年4月去i迹实测通过率97%

朱雀AIGC检测不过怎么办?2026年4月去i迹实测通过率97% 朱雀AIGC检测不过怎么办,这是 2026 年 4 月非常高频的一个搜索词。腾讯朱雀大模型检测在 3 月完成了一次算法升级,过去能过的文章现在一放进去就标红,不少人第一次发现自己写…...

OneNote到Markdown迁移的最佳解决方案:如何用开源工具实现10倍效率提升

OneNote到Markdown迁移的最佳解决方案:如何用开源工具实现10倍效率提升 【免费下载链接】onenote-md-exporter ConsoleApp to export OneNote notebooks to Markdown formats 项目地址: https://gitcode.com/gh_mirrors/on/onenote-md-exporter 面对OneNote笔…...

游戏鼠标指针太小看不清?YoloMouse开源工具三步解决光标可视化难题

游戏鼠标指针太小看不清?YoloMouse开源工具三步解决光标可视化难题 【免费下载链接】YoloMouse Game Cursor Changer 项目地址: https://gitcode.com/gh_mirrors/yo/YoloMouse 在激烈的游戏对战中,你是否曾因鼠标指针太小、颜色与背景融合而迷失方…...

哔哩下载姬终极指南:轻松搞定B站视频离线收藏

哔哩下载姬终极指南:轻松搞定B站视频离线收藏 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等)。…...

【 PyTorch深入浅出】PyTorch从动态图到AI未来的核心引擎

导语:磨刀不误砍柴功,第一期先介绍一下什么是PyToch,知己知彼学起来就可以事半功倍。PyTorch从动态图到AI未来的核心引擎 PyTorch是一个开源的机器学习库,由Meta(原Facebook)AI研究团队于2017年正式发布&am…...

Jable视频下载工具:3分钟掌握永久保存高清视频的完整方案

Jable视频下载工具:3分钟掌握永久保存高清视频的完整方案 【免费下载链接】jable-download 方便下载jable的小工具 项目地址: https://gitcode.com/gh_mirrors/ja/jable-download 你是否曾经遇到过这样的情况:精心收藏的Jable.tv视频突然无法访问…...