网站建设可以帮助企业天津住房和城乡建设厅官方网站
2026/1/30 17:01:45 网站建设 项目流程
网站建设可以帮助企业,天津住房和城乡建设厅官方网站,安卓优化神器,淘客网站模版PHP程序员的逆袭#xff1a;680元搞定CMS编辑器神级插件#xff01; #xff08;敲黑板#xff09;各位西安的码农兄弟们注意啦#xff01;今天给大家分享一个我最近在做的骚操作——用680元预算搞定了客户提出的编辑器神级需求#xff0c;现在…PHP程序员的逆袭680元搞定CMS编辑器神级插件敲黑板各位西安的码农兄弟们注意啦今天给大家分享一个我最近在做的骚操作——用680元预算搞定了客户提出的编辑器神级需求现在连我二舅这种只会用Word的老古董都能在CMS后台愉快地发新闻了一、客户需求有多野客户爸爸的需求堪称编辑器界的灭霸支持Word/Excel/PPT/PDF一键导入要保留样式、图片、公式支持微信公众号内容无损复制LaTeX公式自动转MathML多端高清显示图片自动上传OSS公有云/私有云/混合云都支持必须做成CKEditor插件不能动现有代码预算不超过680元还不够吃顿海底捞拍大腿最绝的是客户说“小张啊我们单位55岁的王主任也要用你搞复杂了他该骂我了”二、技术选型白嫖大法好经过三天三夜实际是摸鱼三天的调研我决定采用以下白嫖方案前端部分Vue3 CKEditor5// src/plugins/OfficeImporter/OfficeImporterPlugin.jsimportPluginfromckeditor/ckeditor5-core/src/plugin;importButtonViewfromckeditor/ckeditor5-ui/src/button/buttonview;importofficeIconfrom./office.svg;exportdefaultclassOfficeImporterextendsPlugin{init(){consteditorthis.editor;editor.ui.componentFactory.add(officeImporter,locale{constbuttonnewButtonView(locale);button.set({label:导入Office文档,icon:officeIcon,tooltip:true});button.on(execute,(){// 调用后端APIconstfileInputdocument.createElement(input);fileInput.typefile;fileInput.accept.doc,.docx,.xls,.xlsx,.ppt,.pptx,.pdf;fileInput.onchangeasync(e){constfilee.target.files[0];constformDatanewFormData();formData.append(file,file);try{constresponseawaitfetch(/api/office/import,{method:POST,body:formData});constresultawaitresponse.json();// 插入HTML到编辑器editor.model.change(writer{constviewFragmenteditor.data.toView(result.html);constmodelFragmenteditor.data.toModel(viewFragment);writer.insert(modelFragment,editor.model.document.getRoot());});}catch(error){console.error(导入失败:,error);}};fileInput.click();});returnbutton;});}}后端部分PHP Mammoth.js Apache POI// api/office/import.php没有上传文件]);exit;}$file$_FILES[file];$allowedTypes[docx,xlsx,pptx,pdf];$extstrtolower(pathinfo($file[name],PATHINFO_EXTENSION));if(!in_array($ext,$allowedTypes)){http_response_code(400);echojson_encode([error不支持的文件类型]);exit;}// 临时保存文件$tmpPathsys_get_temp_dir()./.uniqid()...$ext;move_uploaded_file($file[tmp_name],$tmpPath);// 处理不同类型文件$html;switch($ext){casedocx:// 使用Mammoth.js的PHP封装实际需要自己实现或找替代方案$htmlconvertDocxToHtml($tmpPath);break;casexlsx:$htmlconvertExcelToHtml($tmpPath);break;casepptx:$htmlconvertPptToHtml($tmpPath);break;casepdf:$htmlconvertPdfToHtml($tmpPath);break;}// 处理图片上传到OSS$htmluploadImagesToOss($html);// 处理LaTeX公式简单正则替换实际需要更复杂的解析$htmlpreg_replace_callback(/\\\(.*?)\\\/,function($matches){// 这里应该调用LaTeX解析服务简化演示return.htmlspecialchars($matches[1]).;},$html);unlink($tmpPath);echojson_encode([successtrue,html$html]);functionuploadImagesToOss($html){$ossClientnewS3Client([...]);// 阿里云OSS配置// 使用DOMDocument解析HTML$domnewDOMDocument();$dom-loadHTML($html,LIBXML_HTML_NOIMPLIED|LIBXML_HTML_NODEFDTD);$images$dom-getElementsByTagName(img);foreach($imagesas$img){if(strpos($img-getAttribute(src),data:image)0){// 处理base64图片$imageDatabase64_decode(preg_replace(#^data:image/\w;base64,#i,,$img-getAttribute(src)));$keyuploads/.uniqid()..png;// 上传到OSS$ossClient-putObject([Bucketyour-bucket,Key$key,Body$imageData,ACLpublic-read]);$img-setAttribute(src,https://your-bucket.oss-cn-hangzhou.aliyuncs.com/.$key);}}return$dom-saveHTML();}三、实现过程中的骚操作白嫖开源库用Mammoth.js处理Word文档通过PHP调用Node.js服务用Apache POI处理Excel通过Java中间服务用LibreOffice转换PDF/PPT通过命令行调用曲线救国方案发现完全支持所有需求的开源方案不存在后决定组合多个工具用Python写了个中间服务处理复杂格式运行在Docker里最终用PHP做胶水语言粘合所有服务成本控制绝招阿里云ECS用学生机1核2G只要9.9元/月OSS用低频访问类型存储成本直降70%所有服务跑在同一个服务器上省了负载均衡费用四、最终效果现在客户爸爸的55岁王主任可以点击编辑器上的Office导入按钮选择他的年度工作总结.docx3秒后看到完全保留格式的文档出现在编辑器中连他手绘的流程图用Word画的都完美保留了得意地笑最关键的是整个项目成本阿里云ECS68元/月学生优惠OSS存储免费额度够用我的开发时间0元因为是在公司摸鱼做的五、加入我们的赚钱大军现在这个插件已经在我QQ群223813913里免费分享了加入群还能领1-99元随机红包我自掏腰包接我的外包项目分包我抽10%管理费推荐客户拿20%提成躺着赚钱突然严肃说真的现在经济形势不好咱们程序员更要抱团取暖。我这个方案已经帮3个客户节省了上万元开发费现在他们主动给我介绍新客户。上个月我靠推荐提成就赚了4000多比写代码还轻松最后喊一句西安的兄弟们是时候展现真正的技术了加入QQ群223813913让我们一起用技术赚钱用代码改变生活复制插件说明此教程以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转换成图片上传到服务器中。上传网络图片一键自动上传网络图片自动下载远程服务器图片自动上传远程服务器图片下载示例点击下载完整示例

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询