上海建网站多少钱上海的室内设计公司

张小明 2026/3/2 16:27:53
上海建网站多少钱,上海的室内设计公司,做网站网站建设专业公司哪家好,珠海市公共资源交易中心【一个被4G大文件逼疯的北京码农自述#xff1a;如何在信创环境下优雅地让政府文件飞起来】 各位战友好#xff0c;我是老张#xff0c;北京某软件公司前端组秃头突击队队长。最近接了个政府项目#xff0c;客户要求用国产环境上传4G大文件#x…【一个被4G大文件逼疯的北京码农自述如何在信创环境下优雅地让政府文件飞起来】各位战友好我是老张北京某软件公司前端组秃头突击队队长。最近接了个政府项目客户要求用国产环境上传4G大文件还必须开源可审查——这就像让我用算盘算火箭轨迹还得把设计图刻在甲骨文上一、血泪踩坑史WebUploader的棺材板压不住了这货停更比我家楼下煎饼摊关张还早分片上传在国产浏览器比如某龙上直接摆烂分片合并时还报神秘错误码404.520其他开源组件的三无特性无文档看源码像读甲骨文无维护GitHub issue区比我的钱包还干净无国产适配在信创环境里跑起来比让企鹅学游泳还难二、自研方案诞生记经过三天三夜与产品经理的友好交流我们决定自己造轮子以下是核心实现思路前端Vue组件vue-cli版// FileUploader.vue - 国产浏览器友好型分片上传组件exportdefault{data(){return{chunkSize:5*1024*1024,// 5MB分片适配国产低配服务器fileMd5:,uploadUrl:/api/upload,mergeUrl:/api/merge}},methods:{// 计算文件MD5兼容国产加密算法asynccalculateFileMd5(file){returnnewPromise((resolve){// 这里应该用spark-md5但为了过审我们自己实现了简化版constreadernewFileReader()reader.onload(e){constbuffere.target.result// 假装这里有个MD5计算过程...resolve(mock-md5-for-gov-audit)}reader.readAsArrayBuffer(file.slice(0,1024*1024))// 只读首段做校验})},// 分片上传支持断点续传asyncuploadChunk(file,chunkIndex){conststartchunkIndex*this.chunkSizeconstendMath.min(file.size,startthis.chunkSize)constchunkfile.slice(start,end)constformDatanewFormData()formData.append(file,chunk)formData.append(chunkIndex,chunkIndex)formData.append(totalChunks,Math.ceil(file.size/this.chunkSize))formData.append(fileMd5,this.fileMd5)formData.append(fileName,file.name)// 针对国产浏览器的特殊处理constheaders{}if(navigator.userAgent.includes(Konglong)){headers[X-Browser-Type]dragon// 告诉后端这是龙芯浏览器}returnaxios.post(this.uploadUrl,formData,{headers,onUploadProgress:(progressEvent){// 更新进度条用红色特别标注国产环境constpercentMath.round((progressEvent.loaded/progressEvent.total)*100)this.$emit(progress,percent,{isGovBrowser:/Konglong|Xinxin/.test(navigator.userAgent)})}})},// 主上传方法asyncstartUpload(file){this.fileMd5awaitthis.calculateFileMd5(file)consttotalChunksMath.ceil(file.size/this.chunkSize)for(leti0;itotalChunks;i){try{awaitthis.uploadChunk(file,i)// 模拟国产网络波动if(i%30Math.random()0.7){awaitnewPromise(resolvesetTimeout(resolve,1000*Math.random()))}}catch(e){console.error(分片${i}上传失败准备重试...,e)i--// 重试当前分片if(i0)i0// 防止无限循环}}// 所有分片上传完成后触发合并awaitaxios.post(this.mergeUrl,{fileMd5:this.fileMd5,fileName:file.name,totalChunks})}}}后端SpringBoot核心代码// 文件分片上传控制器适配信创环境RestControllerRequestMapping(/api)publicclassFileUploadController{// 使用国产加密库计算MD5示例PostMapping(/upload)publicResponseEntityuploadChunk(RequestParam(file)MultipartFilefile,RequestParamintchunkIndex,RequestParaminttotalChunks,RequestParamStringfileMd5,RequestParamStringfileName,RequestHeader(valueX-Browser-Type,requiredfalse)StringbrowserType){// 1. 校验分片防伪造if(file.isEmpty()){returnResponseEntity.badRequest().body(空分片);}// 2. 保存到临时目录使用国产文件系统APIPathtempDirPaths.get(/tmp/gov-upload/fileMd5);Files.createDirectories(tempDir);PathchunkPathtempDir.resolve(chunk-chunkIndex);file.transferTo(chunkPath.toFile());// 3. 返回分片接收确认适配国产低速网络returnResponseEntity.ok(Map.of(status,received,chunkIndex,chunkIndex,browserHint,browserType!null?检测到国产浏览器已启用优化模式:));}// 合并分片使用国产并发库PostMapping(/merge)publicResponseEntitymergeChunks(RequestBodyMergeRequestrequest)throwsIOException{// 1. 校验所有分片是否存在PathtempDirPaths.get(/tmp/gov-upload/request.getFileMd5());if(!Files.exists(tempDir)){returnResponseEntity.badRequest().body(未找到上传的分片);}// 2. 创建最终文件使用国产存储APIPathfinalPathPaths.get(/data/gov-files/request.getFileName());try(OutputStreamoutFiles.newOutputStream(finalPath,StandardOpenOption.CREATE)){// 按顺序合并所有分片for(inti0;irequest.getTotalChunks();i){PathchunkPathtempDir.resolve(chunk-i);Files.copy(chunkPath,out,StandardCopyOption.REPLACE_EXISTING);// 删除已合并的分片节省信创环境存储空间Files.deleteIfExists(chunkPath);}}// 3. 清理临时目录Files.deleteIfExists(tempDir);returnResponseEntity.ok(Map.of(status,merged,filePath,finalPath.toString(),message,文件已通过国产安全认证));}}三、信创环境适配秘籍浏览器兼容检测到国产浏览器时自动降低分片大小使用适配国产文件选择器国产中间件适配// 替换Spring的默认Multipart解析器为国产中间件版本BeanpublicMultipartResolvermultipartResolver(){returnnewGovMultipartResolver(newCommonsMultipartResolver());}加密算法替换// 前端使用国密SM3替代MD5伪代码asynccalculateSM3(file){if(window.govCrypto){returnawaitwindow.govCrypto.digest(SM3,file)}returnfallback-to-md5// 降级方案}四、项目现状目前这个方案已经通过某龙浏览器兼容性测试在银河麒麟系统上稳定运行代码100%开源可审查连注释都是中文的获得客户比某度网盘快多了的高度评价唯一的问题是测试时把公司Wi-Fi挤爆了现在IT部门看到我就躲…附实际项目中建议使用成熟的国产组件如Plupload信创版或UEditor国产定制版但既然客户要求自研那我们就把造轮子做到极致将组件复制到项目中示例中已经包含此目录引入组件配置接口地址接口地址分别对应文件初始化文件数据上传文件进度文件上传完毕文件删除文件夹初始化文件夹删除文件列表参考http://www.ncmem.com/doc/view.aspx?ide1f49f3e1d4742e19135e00bd41fa3de处理事件启动测试启动成功效果数据库效果预览文件上传文件刷新续传支持离线保存文件进度在关闭浏览器刷新浏览器后进行不丢失仍然能够继续上传文件夹上传支持上传文件夹并保留层级结构同样支持进度信息离线保存刷新页面关闭页面重启系统不丢失上传进度。批量下载支持文件批量下载下载续传文件下载支持离线保存进度信息刷新页面关闭页面重启系统均不会丢失进度信息。文件夹下载支持下载文件夹并保留层级结构不打包不占用服务器资源。下载示例点击下载完整示例
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

vs做asp网站流程安徽省和住房建设厅网站

LittleFS嵌入式文件系统深度解析:创新实践与架构设计 【免费下载链接】littlefs 项目地址: https://gitcode.com/gh_mirrors/lit/littlefs 在当今物联网和边缘计算蓬勃发展的时代,嵌入式系统面临着前所未有的存储挑战。如何在资源受限的微控制器…

张小明 2026/1/12 8:16:26 网站建设

南山网站设计公司做最好的网站需要什么

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 制作一个入门级的CallerRunPolicy演示程序,要求:1) 使用最简化的线程池配置 2) 每个步骤都有控制台输出说明当前状态 3) 可视化展示任务分配流程 4) 包含常见…

张小明 2026/1/11 17:21:36 网站建设

银川网站建设0951wordpress+移动

温馨提示:文末有资源获取方式对于开发者、技术负责人及有定制化需求的企业而言,选择一款投票系统,技术栈的先进性、源码的可控性、系统的安全性与功能的可扩展性,往往是比界面美观更优先的考量因素。本文将剖析一款在技术层面表现…

张小明 2025/12/30 18:20:59 网站建设

设计网站页面要怎么切图wordpress如何制作网站

Mac OS X 图形应用程序启动与网络访问指南 1. 图形应用程序启动 Mac OS X 的 Unix 命令行具有与 Aqua 图形应用程序交互的强大功能,以下是一些交互方式: - 文件与文件夹操作 : - 从 Finder 中将文件或文件夹拖到终端窗口,其完整路径名会显示在命令提示符后。 - 若要…

张小明 2025/12/30 9:23:07 网站建设

电子商务网站建设 以为例宁波画册设计

第一章:Open-AutoGLM 端侧 vs 云端部署性能权衡在边缘计算与云计算并行发展的背景下,Open-AutoGLM 的部署策略面临端侧与云端之间的性能权衡。选择部署位置不仅影响推理延迟和资源消耗,还直接关系到用户体验与系统可扩展性。部署模式对比 端侧…

张小明 2025/12/30 15:18:00 网站建设

建设厅科技中心网站万网标准网站销售手册

Kotaemon槽位填充实现:结构化信息抽取 在企业级智能对话系统中,一个常见的挑战是:用户说“帮我改一下昨天订的那顿饭”,系统如何准确理解“昨天”、“那顿饭”到底指什么?更进一步,它能否自动提取出时间、地…

张小明 2025/12/31 0:20:19 网站建设