当前位置: 首页 > news >正文

西安网站建设资讯上饶网站建设

西安网站建设资讯,上饶网站建设,wordpress菜鸟教程,网站在百度上搜不到了前端获取文件的md5值,与文件一同传到后端,后端同样对md5值进行校验。如果相同,则文件未被损坏(其实这种方式优点类似于tcp、ip的差错校验,好像token也是这种方式) 项目准备 前端并不可能手写一个算法来实…

前端获取文件的md5值,与文件一同传到后端,后端同样对md5值进行校验。如果相同,则文件未被损坏(其实这种方式优点类似于tcp、ip的差错校验,好像token也是这种方式)

项目准备

前端并不可能手写一个算法来实现校验,于是在gitHub上找到一个spark-md5的js插件
SparkMD5库 library:https://github.com/satazor/SparkMD5

npm i spark-md5  -save

代码处理

在处理过程中,需要注意的是file.onload是一个异步事件,因此使用时需要使用promise封装一下,才能得到异步的返回值
,然后在后面处理ajax请求

export default function (file) {return newPromise(resolve, reject){//声明必要的变量let fileReader = new FileReader()//文件分割方法(注意兼容性)blobSlice = File.prototype.mozSlice || File.prototype.webkitSlice || File.prototype.slice,//文件每块分割2M,计算分割详情chunkSize = 2097152,chunks = Math.ceil(file.size / chunkSize),currentChunk = 0,//每块文件读取完毕之后的处理fileReader.onload = function (e) {console.log("读取文件", currentChunk + 1, "/", chunks);//每块交由sparkMD5进行计算spark.appendBinary(e.target.result);currentChunk++;//如果文件处理完成计算MD5,如果还有分片继续处理if (currentChunk < chunks) {loadNext();} else {console.log("finished loading");console.info("计算的Hash", spark.end());}//处理单片文件的上传function loadNext() {var start = currentChunk * chunkSize,end = start + chunkSize >= file.size ? file.size : start + chunkSize;fileReader.readAsBinaryString(blobSlice.call(file, start, end));}loadNext();}}
}

如果是前端生成文件流,则

let blob = new Blob([text],type:'application/octet-stream')
//blob 转arraybuffer类型 另一篇文章
let md5 = SparkMD5.ArrayBuffer.hash(arraybuffer).toString().toUpperCase();

spark-md5 的详解博客推荐
https://blog.csdn.net/qq_36017964/article/details/131247303

http://www.yayakq.cn/news/97585/

相关文章:

  • 网站游戏怎么制作网站建设通
  • 微商城网站建设案例自贡公司做网站
  • 做视频网站投入多少深圳兆富资本非吸案4人被判刑
  • 有哪些做高考模拟卷的网站一级域名和二级域名
  • 学校营销型网站建设wordpress home index
  • 如何设计一个好网站昭通seo
  • 源码网站跟自己做的网站区别网页 网站及与之相关的概念
  • 做学校网站素材图片素材seo研究中心
  • 企业网站模板是什么网盘做网站空间
  • 校园网站建设方案模板wordpress ua
  • 互联网科技网站网址大全页面设置在哪
  • 网站建设策划书的编制网站换域名做301
  • 广州网站制作怎么做赤峰网站建设建站公司
  • 东莞网站建设 胶粘包装材料宽带固定ip的怎么做网站服务器
  • 做视频网站服务器多少钱阳江房产网房天下
  • 网站建设工种中国建筑网建筑通
  • 女朋友做网站wordpress免费媒体库管理
  • 深圳排名网站dede网站地图
  • 网站被k换域名亳州网站建设公司
  • 网站建设骗子公司自动做微网站
  • 网站小视频怎么做代理商深圳迈瑞医疗器械有限公司官网
  • 有没有专门教做扯面的网站企业网站建设预算
  • iis创建网站长沙品牌网站建设
  • DW做注册网站网站开发公司起名
  • 网站建设商务合同范本wordpress 网页排版
  • 郑州自助建站模板wordpress问答站模板
  • 网站站长如何赚钱seo自己做网站吗
  • 百度权重排名高的网站廊坊做网站公司排名
  • 如何建一个网站多少钱网站admin密码忘记了怎么办
  • 中国建设银行网站维护wordpress免费建站