基于spark-md5对文件进行加密

  • Post author:
  • Post category:其他


之前写了一个基于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 版权协议,转载请附上原文出处链接和本声明。