文件上传一般有两种方式:文件流上传和base64方式上传,毫无疑问,当进行大文件上传时候,转为base64是不现实的,因此用formData方式结合文件流,直接上传到服务器

本文主要结合vue的来讲解,主要知识点有“promise函数、formData对象使用、ajax异步上传、文件切割

//1、这里先在vue的Data中定义几个上传所需要的变量
taskId: '' //区分分包文件名
bytesPerPiece: 1 * 1024 * 1024, // 每个文件切片大小定为1MB .
totalPieces: 0,//文件切片个数
blob: '',//原始文件
start: 0,//第一个分片
end: 0,//最后一个分片
index: 1,//分片次序
filesize: 0,//文件大小
chunk: 0,//文件分片
formData: new FormData(),//后端header所需对象
// 2、分片上传方法--这里的ajax如果项目封装了axios可以直接改为axios,以避免使用jquery,使项目体积增大
fileSlice(){
return new Promise((resolve, reject) => {
var _this = this;
if (this.start < this.filesize) { //判断剩余文件大小,大于起始值执行切割操作
this.end = this.start + this.bytesPerPiece; //规定分片文件节点
if (this.end > this.filesize) { //判断是否是最后一个切片
this.end = this.filesize;
}
this.chunk = this.blob.slice(this.start, this.end); //切割文件
this.sliceIndex = this.index;
this.percentage = parseInt((this.sliceIndex / this.totalPieces) * 100); // 进度提示,如果不需要进度可省略
if(this.percentage == 0){ // 这里是因为当文件过大时候,避免进度显示过慢,影响用户体验
this.percentage = 1;
}
console.log('sliceIndex', this.sliceIndex, 'this.percentage', this.percentage);
this.formData = new FormData();
this.formData.append('file', this.chunk);
$.ajax({
type: 'post',
url: //后端接口
headers: { //后端所需参数
'jwt-token': Auth.getJwtToken(),
taskId: _this.taskId,
chunk: _this.sliceIndex,
size: _this.chunk.size,
chunkTotal: _this.totalPieces,
orginFileName: 'uploadFile'
},
         //传入组装的参数
data: this.formData,
dataType: 'json',
async: true,
cache: false, //上传文件不需要缓存
contentType: false, //需设置为false。因为是FormData对象,且已经声明了属性enctype="multipart/form-data"
processData: false, //需设置为false。因为data值是FormData对象,不需要对数据做处理
success: function(res) {
if (_this.sliceIndex == _this.totalPieces) { //判断是否为最后一个文件,如果是,赋值后端输出路径 像服务端上传文件
_this.upPath = res.data.path;
_this.buttonLoading = false;
}
if(res.code == 0){
resolve('0');
}else{
_this.clearUploadFile();
reject(res.message);
}
},
error: function(res) { //异常判断
reject('上传文件失败,请重新上传!', this.fileList = []);
_this.$message({
message: res.message,
type: 'error'
});
return 'break';
}
});
}
_this.start = this.end;
_this.index++;
});
},
async fileUpload(file) { //此处主要给文件加32位随机数
console.log(file.file);
this.blob = file.file;
this.filesize = this.blob.size;
this.totalPieces = Math.ceil(this.filesize / this.bytesPerPiece);
function randomWord(randomFlag, min, max) {
// eslint-disable-next-line one-var
let str = '',
range = min,
arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's',
't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G',
'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U',
'V', 'W', 'X', 'Y', 'Z'
];
// 随机产生
if (randomFlag) {
range = Math.round(Math.random() * (max - min)) + min;
}
for (var i = 0; i < range; i++) {
let pos = Math.round(Math.random() * (arr.length - 1));
str += arr[pos];
}
return str;
} this.taskId = randomWord(false, 32); for(let i = 0; i < this.totalPieces; i++){
let ttt = await this.fileSlice().catch((res) => {
this.$message({
message: res,
type: 'error'
});
});
if(ttt != 0){
break;
}
}
},

 

//3、中止文件上传
clearUploadFile(){
// buttonLoading
this.buttonLoading = false;
this.totalPieces = 0;
this.blob = '';
this.start = 0;
this.end = 0;
this.index = 1;
this.filesize = 0;
this.chunk = 0; this.percentage = 0;
// 清空文件表
this.fileList = [];
const mainImg = this.$refs.upload;
if (mainImg && mainImg.length) {
mainImg.forEach(item => {
         // item.uploadFiles.length = 0;
item.clearFiles();
});
}
},
 

小谢第7问:js前端如何实现大文件分片上传、上传进度、终止上传以及删除服务器文件?的更多相关文章

  1. 小谢第10问:前端JS下载文件、表格

    对于小型文件及表格下载,一般采用a标签形式 <buttonb @click="downloadTemplate()">模板下载</button> downl ...

  2. 小谢第6问:js中,filter函数是怎么使用的

    数组的常用方法filter,今天在做数组筛选的时候用到需要将有重复的数组去除,因此用到这个函数,主要用到-- 选择需要的属性,最终留下想要的数组,如果刚开始的话可以看下下面代码 let nums = ...

  3. 小谢第23问: chorme的性能优化工具

    问题场景:在前端日趋工程化的今天,前端性能优化是一名合格的前端工程师必备的技能,那么,如何正确的使用性能分析工具呢? 解决方案: 性能分析的流程: 在开发中我一般使用公司开发的测试脚本-kbase-w ...

  4. 小谢第37问:关于websocket推送进度,本地保存进度条,然后跳出页面进入后再显示的问题

    1.主要技术点:sessionStorage 会话存储进度 这里在使用之前,顺便说一下cookie.sessionStorage.localStorage 共同点:都是保存在浏览器端,且同源的. 区别 ...

  5. 小谢第50问:vuex的五个属性-使用-介绍

    一.Vuex 是什么? 官网:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 关键词:状态 ...

  6. 小谢第58问:nuxt搭建企业官网

    最近公司要重构公司官网,jq+bootstrap 改为了vue,刚开始我以为用vue不是挺好的嘛,后来才发现,有于vue单页面的特性,不利于搜索引擎的抓取,因此在seo方面需要另外想办法,于是乎,就找 ...

  7. 小谢第8问:ui框架的css样式如何更改

    目前有三种方法, 1.使用scss,增加样式覆盖,但是此种方法要求css的className需要与框架内的元素相一致,因此修改时候需要特别注意,一个父级的不同就可能修改失败 2.deep穿透,这种方法 ...

  8. 小谢第2问:后端返回为数组list时候,怎么实现转为tree

    要求后端返回给我的list时候,在数组中定义有id , parentid, 可以用双重循环的方法,得到tree需要的数据结构,这样得到的数据就可以直接复制给树组件的data啦const oldData ...

  9. 小谢第1问:为什么要写blog

    一直犹豫了好久,终于在csdn上弄好了自己的博客账号,感谢平台,以后在工作的过程中,遇到不懂得问题,解决后,会在这里记录下自己所遇到的问题

随机推荐

  1. Java:手写幼儿园级线程安全LRU缓存X探究影响命中率的因素

    最近遇到一个需求,需要频繁访问数据库,但是访问的内容只是 id + 名称 这样的简单键值对. 频繁的访问数据库,网络上和内存上都会给数据库服务器带来不小负担. 于是打算写一个简单的LRU缓存来缓存这样 ...

  2. D. Carousel(分类+构造)

    \(题目的要求似乎很低:只需要不同类的相邻元素不同色就行了.\) 下面的讨论的话,实际上最后一个点是关键,要想到怎么让最后一个点不开新的颜色就简单了. \(分情况讨论:\) \(\color{Red} ...

  3. [蓝桥杯2018初赛]小朋友崇拜圈(dfs找环)

    传送门 思路: 题意大意:n条有向边,找出最大环. 我们发现,如果一个小朋友没有被任何人崇拜,那么他一定不位于环中.为此我们可以设置一个indug数组预处理.如果2被崇拜了那么indug[2]就加加, ...

  4. boost在Qt中的使用

    一.说明 理论上,Qt和boost是同等级别的C++库,如果使用Qt,一般不会需要再用boost,但是偶尔也会有特殊情况,比如,第三方库依赖等等.本文主要介绍boost在windows Qt(MinG ...

  5. [hdu5389 Zero Escape]数根的性质,DP

    题意:把n个数(1-9)放到A集合和B集合里面去,使得A集合里面的数的数根为a,B集合里面的数的数根为b,也可以只放在A或B任一个集合里面.求方法总数.比如A={2,4,5},则A的数根为[2+4+5 ...

  6. Codeforces Round #643 (Div. 2)(C ~ E)

    C. Count Triangles 题目链接 : https://codeforces.com/contest/1355/problem/C 题目大意 : 给你 A , B , C , D 问有多少 ...

  7. JavaWeb学习之JSP(三) EL表达式

    EL表达式 什么是EL表达式   EL,Expression Language,表达式语言,是一种在JSP页面中获取数据的简单方式,通过${变量名}的方式可以获取到值,需要注意的是EL只能从 page ...

  8. X-CTF(REVERSE高级) 666

    主函数输入的字符会和key比较长度和enflag比较内容,所以这道题的flag和输入有关 key长度为0x12,enflag的值为:izwhroz""w"v.K" ...

  9. 仅需60秒,使用k3sup快速部署高可用K3s集群

    作者简介 Dmitriy Akulov,连续创业者,16岁时搭建了开源CDN公共服务jsDelivr的v1版本.目前是边缘托管平台appfleet创始人. 原文链接: https://ma.ttias ...

  10. 我们为什么推荐在Json中使用string表示Number属性值?

    在这篇简短的文章中,我将解释在使用JSON传输数据时,为什么浮点数或大十进制值应表示为字符串 . long类型引发的诡异情况 长话短说,同事在利用swagger对接后端API时,诡异的发现swagge ...