注册 X
提交 注:点击提交后系统会发送邮件到邮箱验证!(仅支持中国大陆邮箱)
我已阅读并同意 服务条款
首页 > IT技术笔记 > 查看笔记

spark-md5.js计算文件md5,实现文件秒传

js计算文件md5,实现文件秒传

引入spark-md5.js

1、计算文件md5

   //计算文件md5,实现文件秒传
document.getElementById('fileinput-demo-1').addEventListener('change', function () {
  var blobSlice = File.prototype.slice || File.prototype.mozSlice || File.prototype.webkitSlice,
        file = this.files[0],
        chunkSize = 2097152,                             // Read in chunks of 2MB
        chunks = Math.ceil(file.size / chunkSize),
        currentChunk = 0,
        spark = new SparkMD5.ArrayBuffer(),
        fileReader = new FileReader();
  fileReader.onload = function (e) {
     console.log('read chunk nr', currentChunk + 1, 'of', chunks);
     spark.append(e.target.result);                   // Append array buffer
     currentChunk++;
     if (currentChunk < chunks) {
        loadNext();
     } else {
        console.log('finished loading');
        var md5 = spark.end();
        $("#file-md5").val(md5);     //md5计算完成,往自定义的输入框设置md5
        console.info('computed hash', md5);  // Compute hash
     }
  };
  fileReader.onerror = function () {
     console.warn('oops, something went wrong.');
  };
  function loadNext() {
     var start = currentChunk * chunkSize,
           end = ((start + chunkSize) >= file.size) ? file.size : start + chunkSize;
     fileReader.readAsArrayBuffer(blobSlice.call(file, start, end));
  }
  loadNext();
});


2、常规字符串使用

var hexHash = SparkMD5.hash('Hi there');        // hex hash
var rawHash = SparkMD5.hash('Hi there', true);  // OR raw hash (binary string)


3、字符串追加使用

var spark = new SparkMD5();
spark.append('Hi');
spark.append(' there');
var hexHash = spark.end();                      // hex hash
var rawHash = spark.end(true);                  // OR raw hash (binary string)


	        
			
	      

 打赏        分享



评论

邮箱: 昵称:
\n