企业网站模板seo四网一体网站建设方案

张小明 2025/12/27 23:12:45
企业网站模板seo,四网一体网站建设方案,中国铁建网站,网站建设的域名续费Vue大文件上传方案重构#xff1a;从WebUploader到分片断点续传的实践 作为项目技术负责人#xff0c;近期在处理4GB级文件上传时遇到WebUploader组件的兼容性瓶颈#xff08;尤其在IE11及国产浏览器中频繁出现内存溢出#xff09;。经过两周技术调研与POC验证#xff0c…Vue大文件上传方案重构从WebUploader到分片断点续传的实践作为项目技术负责人近期在处理4GB级文件上传时遇到WebUploader组件的兼容性瓶颈尤其在IE11及国产浏览器中频繁出现内存溢出。经过两周技术调研与POC验证最终采用基于HTML5 File API的分片上传方案结合PHP后端实现可靠的断点续传机制。现将技术选型与核心实现分享如下一、技术选型依据兼容性需求需覆盖Chrome/Firefox/Edge/IE11及国产浏览器360安全浏览器、QQ浏览器等排除纯WebWorker方案。性能要求4GB文件需支持动态分片5MB-10MB自适应并发上传3-5通道秒传验证MD5/SHA1可靠性保障断点续传需记录上传状态至IndexedDB支持浏览器崩溃恢复网络中断重试跨设备续传二、核心架构设计前端实现Vue3 Composition API// src/utils/fileUploader.jsexportclassFileChunkUploader{constructor(file,options{}){this.filefilethis.chunkSizeoptions.chunkSize||5*1024*1024// 5MBthis.concurrentoptions.concurrent||3this.uploadUrloptions.uploadUrlthis.checkUrloptions.checkUrlthis.mergeUrloptions.mergeUrlthis.chunksMath.ceil(file.size/this.chunkSize)this.uploadedChunksnewSet()this.controllernewAbortController()}// 生成文件唯一标识含修改时间戳防冲突asyncgenerateFileId(){constbufferawaitthis.file.slice(0,1024*1024).arrayBuffer()// 取首1MB计算哈希consthashawaitcrypto.subtle.digest(SHA-256,buffer)returnArray.from(newUint8Array(hash)).map(bb.toString(16).padStart(2,0)).join()_this.file.lastModified}// 检查已上传分片asynccheckUploadStatus(){constfileIdawaitthis.generateFileId()constresawaitfetch(${this.checkUrl}?fileId${fileId}chunks${this.chunks},{method:HEAD,signal:this.controller.signal})if(res.ok){constrangeres.headers.get(Content-Range)if(range){constuploadedparseInt(range.split(/)[1].split(-)[1])/this.chunkSizefor(leti0;iuploaded;i)this.uploadedChunks.add(i)}}}// 分片上传核心逻辑asyncupload(){constfileIdawaitthis.generateFileId()awaitthis.checkUploadStatus()constuploadTasks[]for(leti0;ithis.chunks;i){if(this.uploadedChunks.has(i))continueconststarti*this.chunkSizeconstendMath.min(startthis.chunkSize,this.file.size)constchunkthis.file.slice(start,end)constformDatanewFormData()formData.append(file,chunk)formData.append(chunkIndex,i)formData.append(totalChunks,this.chunks)formData.append(fileId,fileId)formData.append(fileName,this.file.name)uploadTasks.push(fetch(this.uploadUrl,{method:POST,body:formData,signal:this.controller.signal}).then(res{if(!res.ok)thrownewError(Chunk${i}upload failed)this.uploadedChunks.add(i)returnres.json()}))// 并发控制if(uploadTasks.lengththis.concurrent){awaitPromise.race(uploadTasks)}}// 等待剩余任务完成awaitPromise.all(uploadTasks)// 触发合并请求constmergeResawaitfetch(this.mergeUrl,{method:POST,headers:{Content-Type:application/json},body:JSON.stringify({fileId,fileName:this.file.name})})returnmergeRes.json()}abort(){this.controller.abort()}}后端实现PHP// upload_handler.phpheader(Access-Control-Allow-Origin: *);header(Access-Control-Allow-Methods: POST, OPTIONS);$uploadDir/tmp/uploads/;if(!file_exists($uploadDir))mkdir($uploadDir,0777,true);// 分片上传接口if($_SERVER[REQUEST_METHOD]POSTisset($_FILES[file])){$chunkIndex$_POST[chunkIndex]??0;$totalChunks$_POST[totalChunks]??1;$fileId$_POST[fileId];$fileName$_POST[fileName];$chunkPath$uploadDir.$fileId..part.$chunkIndex;if(move_uploaded_file($_FILES[file][tmp_name],$chunkPath)){// 记录上传进度可选存入Redis$progressFile$uploadDir.$fileId..progress;file_put_contents($progressFile,$chunkIndex./.$totalChunks);http_response_code(201);echojson_encode([statussuccess,chunk$chunkIndex]);}else{http_response_code(500);echojson_encode([statuserror]);}exit;}// 合并文件接口if($_SERVER[REQUEST_METHOD]POSTisset($_POST[fileId])){$fileId$_POST[fileId];$fileName$_POST[fileName];// 检查所有分片是否存在$allChunksExisttrue;$totalChunks0;for($i0;;$i){if(!file_exists($uploadDir.$fileId..part.$i)){if($i0)break;// 没有分片$allChunksExistfalse;break;}$totalChunks$i1;}if($allChunksExist$totalChunks0){$finalPath/uploads/.uniqid()._.$fileName;$fpfopen($finalPath,wb);if($fp){for($i0;$i$totalChunks;$i){$chunkPath$uploadDir.$fileId..part.$i;fwrite($fp,file_get_contents($chunkPath));unlink($chunkPath);// 清理分片}fclose($fp);// 清理进度文件unlink($uploadDir.$fileId..progress);echojson_encode([statussuccess,path$finalPath]);}else{http_response_code(500);echojson_encode([statusmerge_error]);}}else{http_response_code(400);echojson_encode([statusmissing_chunks]);}exit;}// 检查上传状态接口HEAD方法if($_SERVER[REQUEST_METHOD]HEAD){$fileId$_GET[fileId];$totalChunks$_GET[chunks]??0;$uploaded0;for($i0;$i$totalChunks;$i){if(file_exists($uploadDir.$fileId..part.$i)){$uploaded;}}header(Content-Range: 0-.($uploaded-1)./.$totalChunks);exit;}三、关键问题解决IE11兼容方案使用FileReader.readAsArrayBuffer替代Blob.slice需polyfill通过XMLHttpRequest替代Fetch API引入es6-promise和fetch-ie8polyfill内存优化// 使用流式读取处理超大文件asyncreadFileAsChunks(file,chunkSize){constchunks[]constfileReadernewFileReader()letoffset0returnnewPromise((resolve){functionreadNext(){constblobfile.slice(offset,offsetchunkSize)fileReader.onload(e){chunks.push(e.target.result)offsetchunkSizeif(offsetfile.size){readNext()}else{resolve(chunks)}}fileReader.readAsArrayBuffer(blob)}readNext()})}断点续传存储使用IndexedDB存储上传状态// 存储上传记录asyncsaveUploadRecord(fileId,chunks){returnnewPromise((resolve){constrequestindexedDB.open(FileUploaderDB,1)request.onupgradeneeded(e){constdbe.target.resultif(!db.objectStoreNames.contains(uploads)){db.createObjectStore(uploads,{keyPath:fileId})}}request.onsuccess(e){constdbe.target.resultconsttxdb.transaction(uploads,readwrite)conststoretx.objectStore(uploads)store.put({fileId,chunks,timestamp:Date.now()})tx.oncomplete(){db.close()resolve()}}})}四、性能测试数据在200Mbps带宽环境下对4.2GB视频文件进行测试方案平均速度成功率内存占用WebUploader1.2MB/s78%1.8GB本方案5MB分片8.5MB/s99%320MB本方案10MB分片12.3MB/s97%580MB五、部署建议Nginx配置优化client_max_body_size 10G; client_body_timeout 3600s; proxy_read_timeout 3600s;PHP-FPM调整; php.ini upload_max_filesize 10G post_max_size 10G max_execution_time 3600 max_input_time 3600分片清理策略设置7天自动清理未完成分片使用Cron定时任务执行find/tmp/uploads/ -name*.part*-mtime 7 -execrm{}\;该方案已在政府项目国产化环境银河麒麟V10 龙芯3A5000中稳定运行3个月支持单文件20GB上传日均处理量达1.2TB。完整实现代码已开源至GitHub示例仓库包含Webpack配置和浏览器兼容性测试报告。将组件复制到项目中示例中已经包含此目录引入组件配置接口地址接口地址分别对应文件初始化文件数据上传文件进度文件上传完毕文件删除文件夹初始化文件夹删除文件列表参考http://www.ncmem.com/doc/view.aspx?ide1f49f3e1d4742e19135e00bd41fa3de处理事件启动测试启动成功效果数据库下载示例点击下载完整示例
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

跑步机 东莞网站建设app拉新推广怎么做

图书馆的白炽灯将凌晨两点映照得如同白昼,论文开题报告的空白文档上,光标在“研究意义”四个字后规律地闪烁,已经过去了快一个小时。 这种被称为“开题困境”的场景,是无数学生学术生涯的起点与梦魇。面对导师“选题缺乏新意”、“…

张小明 2025/12/23 1:33:08 网站建设

福建建设局网站网站百度收录删除

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 设计一个极简Word快速编号工具:用户选中公式后点击插件按钮,自动在公式右侧添加[1][2]...的连续编号。支持批量选择多个公式一键编号。提供3种预设样式可选…

张小明 2025/12/23 1:32:06 网站建设

公众号做 视频网站微信h5页面制作小程序

Windows 8使用指南:安装、快捷键与触摸手势全解析 在现代计算机使用中,Windows 8系统凭借其独特的界面和功能,为用户提供了丰富的操作体验。本文将详细介绍Windows 8系统的安装步骤、各类快捷键以及触摸手势的使用方法,帮助你更高效地使用这一操作系统。 一、Windows 8系…

张小明 2025/12/23 1:31:05 网站建设

html5网站框架南阳手机网站建设

卡尔曼滤波simulink实例,卡尔曼滤波在温度测量中的应用今天咱们来聊一个在工程领域特别实用的技术——卡尔曼滤波。这玩意儿名字听着挺唬人,但说白了就是个"带脑子的数据过滤器"。就拿温度测量来说,传感器数据总带着点噪声对吧?这时…

张小明 2025/12/23 1:30:03 网站建设

自贡 网站建设东莞网站开发公司

🎬 HoRain 云小助手:个人主页 ⛺️生活的理想,就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站,性价比超高,大内存超划算!忍不住分享一下给大家。点击跳转到网站。 目录 ⛳️ 推荐 …

张小明 2025/12/23 1:29:01 网站建设

齐河网站建设公司wordpress v4

深入理解ISO 26262:汽车功能安全标准完整指南 【免费下载链接】ISO26262中文版本PDF下载分享 ISO 26262 中文版本 PDF 下载 项目地址: https://gitcode.com/Open-source-documentation-tutorial/442c6 ISO 26262标准作为汽车电子系统功能安全的基石&#xff…

张小明 2025/12/23 1:26:58 网站建设