**Hive**:基于 Hadoop 的数据仓库工具,提供类 SQL(HiveQL)接口,将查询转换为 MapReduce/Tez/Spark 任务

核心内容摘要

Fish-Speech 1.5应用案例:快速生成有声书、智能客服语音
创客匠人深度解析:知识产品化的系统架构与AI智能体协同机制

生态协同机制赋能高校成果转化,实现学术产业双赢

前端老哥的“懒人”大文件上传方案Vue3原生JS兄弟们我是辽宁一名“头发没秃但代码量秃”的前端程序员最近接了个外包活——给客户做文件管理系统核心需求就仨字儿“稳、省、兼容”客户拍着桌子说“20G大文件、文件夹上传下载、加密、断点续传预算100块你看着办” 我揉着太阳穴想“行吧谁让我爱交朋友呢今天把这系统的‘压箱底’代码扒给你再送你份‘保姆级’文档保证你直接交给客户收钱不慌”

需求拆解客户的“魔鬼”要求我用“懒人”方案搞定先给大伙儿捋捋客户的“奇葩”需求其实是行业真实痛点大文件上传20G比我家冰箱还沉我家冰箱100斤。

文件夹上传下载必须保留层级比如/项目/周报/

10.

docx用户每天传几千个文件夹子文件几万。

加密传输用AESSM4太冷门客户要“能跑就行”存储也加密客户说“数据比我家猫还金贵”。

断点续传关闭网页、重启电脑都不丢进度用户“我上次传到99%关浏览器就没了想砸键盘”。

兼容IE9客户业务部还有一批“古董机”Windows 7IE9不能扔啊前端Vue3客户指定框架还说“年轻人就得用新东西”老哥我40岁了还在学Vue3头秃。

前端核心代码Vue3原生JS附“懒人”注释

文件夹上传保留层级兼容IE9IE9不支持webkitDirectory所以文件夹上传只能“曲线救国”——让用户手动选择文件夹现代浏览器用showDirectoryPickerIE9提示“不支持请用Chrome”。

但客户说“用户主要用文件夹传资料”所以重点处理现代浏览器IE9给个友好提示。

import { ref, onMounted } from vue; import CryptoJS from crypto-js; // 加密库npm install crypto-js // 全局状态 const uploadTasks ref([]); // 上传任务列表 const isIE9 ref(false); // 是否是IE9浏览器 const chunkSize 5 * 1024 * 1024; // 分块大小5MB20G4000块合理 const uploadQueue ref([]); // 待上传队列 const MAX_CONCURRENT 3; // 最大并发上传数避免浏览器崩溃 // 初始化检测浏览器类型IE9兼容 onMounted(() { isIE

value /*cc_on*/false || !!document.documentMode 9; }); /* 样式懒人版简单好看兼容旧浏览器 */ .uploader-container { max-width: 800px; margin: 20px auto; padding: 20px; font-family: 微软雅黑, sans-serif; } .upload-btn-group { margin-bottom: 20px; } .upload-btn-group button { padding: 8px 16px; margin-left: 10px; background: #409eff; color: white; border: none; border-radius: 4px; cursor: pointer; } .progress-list { border: 1px solid #ebeef5; border-radius: 4px; padding: 10px; } .progress-item { margin-bottom: 15px; padding: 10px; background: #f8f9fa; border-radius: 4px; } .file-info { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 14px; } .progress-bar { height: 20px; background: #e9ecef; border-radius: 10px; position: relative; overflow: hidden; } .progress-fill { height: 100%; background: #67c23a; transition: width

3s; } .progress-text { position: absolute; top: 0; right: 10px; line-height: 20px; color: white; font-size: 12px; } .ie-warning { color: #f56c6c; margin-left: 10px; font-size: 12px; }

关键功能说明老哥踩过的坑帮你避开

文件夹层级保留懒人秘诀现代浏览器用showDirectoryPicker递归遍历记录每个文件的fullPath如/项目/周报/

10.

docx。

后端收到文件后按fullPath创建目录比如mkdir -p /项目/周报再保存文件后端代码用Java的Files.createDirectories。

断点续传跨浏览器会话懒人福音用localStorage存每个文件的上传进度upload_${fileId}_progress页面刷新/重启电脑都不丢。

上传前检查服务端是否已接收分块/api/check-chunk接口避免重复上传服务端存已接收的分块MD5。

加密传输AES懒人专用前端用CryptoJS.AES.encrypt加密分块内容后端用相同密钥解密密钥建议用户输入密码用PBKDF2派生示例简化了。

注意密钥不能硬编码实际项目中让用户输入密码前端用CryptoJS.PBKDF2生成密钥防暴力破解。

兼容IE9懒人兼容方案引入es5-shim、html5shiv、whatwg-fetch等polyfill在index.html中添加IE9不支持showDirectoryPicker提示用户用Chrome/Firefox客户业务部要兼容只能这样。

开发文档交给客户的“说明书”懒人版

环境要求懒人必备前端Vue3 CLI、Node.js

Chrome/FirefoxIE9需额外polyfill。

后端SpringBoot

2.

Java

MySQL

7。

服务器LinuxCentOS/Ubuntu、Nginx部署前端、IIS部署后端可选。

安装步骤懒人一键搞定克隆项目git clone https://github.com/你的仓库/大文件上传系统.git。

安装前端依赖cd frontend npm install懒人用cnpm更快。

配置后端修改application.properties中的数据库连接、文件存储路径file.upload.path./uploads。

启动后端mvn spring-boot:run懒人用IDEA直接点运行。

启动前端npm run dev懒人用VS Code的终端。

3.

注意事项懒人避坑指南文件夹上传IE9不支持提示用户用Chrome/Firefox客户业务部要兼容只能这样。

加密密钥示例用了固定密钥实际需让用户输入密码用CryptoJS.PBKDF2派生密钥防止暴力破解。

大文件分块chunkSize建议5MB20G4000块平衡速度和内存。

并发限制MAX_CONCURRENT3避免浏览器崩溃可根据用户电脑配置调整。

最后唠叨老哥的心里话兄弟这套代码我调试了整整两周踩过IE9的坑、分块合并的坑、加密性能的坑现在基本能跑通了。

虽然还有优化空间比如SM4加密、断点续传的服务端校验增强但应付客户演示小项目完全够用要是客户要更复杂的功能比如秒传、多线程下载咱们可以群里一起讨论——我建了个QQ群374992201里面有做后端的、测试的、产品经理平时接单、技术交流都在这儿。

群里天天发红包1~99元推荐项目还能拿20%提成比打工香多了对了要是你接了这单记得请我喝奶茶微信转账就行——毕竟老哥我把压箱底的代码都掏出来了最后毕业找工作/接外包咱们一起加油将组件复制到项目中示例中已经包含此目录引入组件配置接口地址接口地址分别对应文件初始化文件数据上传文件进度文件上传完毕文件删除文件夹初始化文件夹删除文件列表参考http://www.ncmem.com/doc/view.aspx?ide1f49f3e1d4742e19135e00bd41fa3de处理事件启动测试启动成功效果数据库效果预览文件上传文件刷新续传支持离线保存文件进度在关闭浏览器刷新浏览器后进行不丢失仍然能够继续上传文件夹上传支持上传文件夹并保留层级结构同样支持进度信息离线保存刷新页面关闭页面重启系统不丢失上传进度。

下载示例点击下载完整示例

黄金网站免费观看无需下载安装-黄金网站免费观看无需下载安装应用

百度百家号客服电话人工服务

123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123 123