123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- import SparkMD5 from 'spark-md5'
-
- export function getFilemd5sum(ofile) {
- return new Promise((resolve, reject) => {
- let file = ofile;
- let tmp_md5;
- let blobSlice = File.prototype.slice || File.prototype.mozSlice || File.prototype.webkitSlice,
- // file = this.files[0],
- chunkSize = 8097152, // Read in chunks of 2MB
- chunks = Math.ceil(file.size / chunkSize),
- currentChunk = 0,
- spark = new SparkMD5.ArrayBuffer(),
- fileReader = new FileReader();
-
- fileReader.onload = function (e) {
- spark.append(e.target.result); // Append array buffer
- currentChunk++;
-
- if (currentChunk < chunks) {
- loadNext();
- } else {
- tmp_md5 = spark.end();
- resolve(tmp_md5)
- }
- };
-
- fileReader.onerror = function () {
- reject('error');
- };
-
- loadNext = () => {
- var start = currentChunk * chunkSize,
- end = ((start + chunkSize) >= file.size) ? file.size : start + chunkSize;
- fileReader.readAsArrayBuffer(blobSlice.call(file, start, end));
- }
- loadNext();
- })
- }
-
- export function getBase64(file) {
- return new Promise((resolve, reject) => {
- var reader = new FileReader();
- reader.readAsDataURL(file);
- reader.onload = function (e) {
- resolve(e.target.result);
- }
- reader.onerror = function() {
- reject('error')
- }
- });
- }
|