-2

Plupload 插件回调获取上传文件 md5.

Plupload 有同样的问题,但是其他人无法得到正确答案。

下面的代码是我的测试。请确认。

  • 进口火花-md5
<!-- spark-md5 -->
<script src="https://cdn.bootcdn.net/ajax/libs/spark-md5/3.0.0/spark-md5.js"></script>
  • 计算 md5 方法
// file md5 method
function calculate(file, callBack) {
    let fileReader = new FileReader(),
        blobSlice = File.prototype.mozSlice || File.prototype.webkitSlice || File.prototype.slice,
        chunkSize = 2097152,
        // read in chunks of 2MB
        chunks = Math.ceil(file.size / chunkSize),
        currentChunk = 0,
        spark = new SparkMD5();
    fileReader.onload = function(e) {
        spark.appendBinary(e.target.result); // append binary string
        currentChunk++;
        if (currentChunk < chunks) {
            loadNext();
        } else {
            callBack(spark.end());
        }
    };

    function loadNext() {
        let start = currentChunk * chunkSize,
            end = start + chunkSize >= file.size ? file.size : start + chunkSize;
        fileReader.readAsBinaryString(blobSlice.call(file, start, end));
    };
    loadNext();
}
  • 文件上传回调获取文件md5
// 文件上传回调
function uploadCallback(status, remote_path, filename, callback_params, file) {
    // 调用计算md5的方法
    calculate(file.getNative(), function(md5) {
        console.log(md5); //hash值
    });
    // other code ....
    // ....
});

上传 https://www.phpin.net/tools/plupload/

4

1 回答 1

0

我使用这个网站的 calc 文件 md5 与 up 代码进行比较。这是正确的。

HTML5 文件哈希在线计算器

于 2021-05-26T08:46:46.573 回答