admin管理员组文章数量:1639675
之前写了一个基于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));
}
}
版权声明:本文标题:基于spark-md5对文件进行加密 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dongtai/1729294480a1194555.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论