之前写了一个基于AWS.S3的大视频上传,现在项目要求对上传同一个文件不调用上传AWS的接口,而直接把原来的链接直接返回。因此对文件进行md5加密。因为对同一个文件返回的md5加密是一样,因此通过spark-md5组件进行加密。
1、安装和引入
npm i spark-md5 // 安装spark-md5
import SparkMD5 from 'spark-md5'
2、进行加密
getFileMd5(file) {
let that = this;
let blobSlice = File.prototype.slice || File.prototype.mozSlice || File.prototype.webkitSlice,
chunkSize = 1024 * 1024 * 100
chunks = Math.ceil(file.size / chunkSize),
currentChunk = 0,
spark = new SparkMD5.ArrayBuffer(),
fileReader = new FileReader();
fileReader.onload = (e) => {
spark.append(e.target.result);
currentChunk++;
let progress = Math.floor((currentChunk / chunks) * 100);
that.precent = progress;
if (currentChunk < chunks) {
loadNext();
} else {
console.log(spark.end()); // 最终的md5加密码
}
}
function loadNext() {
let start = currentChunk * chunkSize,
end = ((start + chunkSize) >= file.size) ? file.size : start + chunkSize;
fileReader.readArrayBuffer(blobSlice.call(file, start, end));
}
}
版权声明:本文为qq1246877006原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。