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

哪个网站代做装修效果图谷歌seo服务公司

哪个网站代做装修效果图,谷歌seo服务公司,自己做网站的服务器,网上超市网站的设计与实现问题记录原因: 因为需要实现网络文件的上传,结果是由前端实现,方式是一边下载,一遍上传文件,小文件直接上传,大文件进行切片,切片大小和下载大小有关,特此记录。 1.实现方案 fetc…

问题记录原因:

因为需要实现网络文件的上传,结果是由前端实现,方式是一边下载,一遍上传文件,小文件直接上传,大文件进行切片,切片大小和下载大小有关,特此记录。

1.实现方案

fetch进行网络连接的下载,在请求的返回对象中调用response.body.getReader(),这里是读取文件流,便于监听,读取的方式为reader.read(),它的返回对象中包含,文件对象和完成状态,这样就能实现,循环执行下载的动作知道,状态为完成停止。

2.步骤代码

1)下载

const response: any = await fetch(downloadUrl);
const reader = response.body.getReader();
// 读取响应的文件字节数
const contentLength = +response.headers.get('Content-Length');

2)上传

使用MD5计算文件的hash进行分片上传

let receivedLength = 0;
// 分片上传的话需要计算每一片文件的hash,我们使用MD5
const spark = new SparkMD5.ArrayBuffer();
while(true) {const {done, value} = await reader.read();if (done) {// 计算整个文件的hashconst finalHash = spark.end();console.log('下载&上传完成:', finalHash);break;}// 更新整个文件的hashspark.append(value);receivedLength += value.length;console.log(`下载进度: ${receivedLength} / ${contentLength}`);// 创建一个新的SparkMD5实例来处理当前分片const chunkHash = SparkMD5.ArrayBuffer.hash(value); // 计算当前分片的hashconst offset = receivedLength - value.length;// console.log(contentLength, offset, chunkHash, hash, value.length);// 上传这个分片,这里执行接口...
}

 contentLength, offset, chunkHash, hash, value.length,这些参数是分片上传所需要的,依次是:

文件的大小,分片的偏移量,每一片的hash(这个参数可选),整个文件的hash(这个需要提前计算出来),每一个分片的大小;

3.拓展

1)计算大文件的hash

可以参考:【文件比较】前端上传比较内容及名字-CSDN博客

2)content-type类型与文件类型的对应关系

不全面,只是涵盖大多文件类型:

const getFileTypeByContentType = (contentType: string) => {let type = ['image/jpeg', 'image/pjpeg'].includes(contentType) ? 'jpg':['image/png'].includes(contentType) ? 'png':['image/gif'].includes(contentType) ? 'gif':['image/svg+xml'].includes(contentType) ? 'svg':['video/mp4'].includes(contentType) ? 'mp4':['video/quicktime'].includes(contentType) ? 'mov':['text/html'].includes(contentType) ? 'html':['text/markdown'].includes(contentType) ? 'md':['text/plain'].includes(contentType) ? 'txt':['text/csv'].includes(contentType) ? 'csv':['application/json'].includes(contentType) ? 'json':['application/x-yaml', 'text/yaml'].includes(contentType) ? 'yaml':['application/pdf'].includes(contentType) ? 'pdf':['application/msword'].includes(contentType) ? 'doc':['application/vnd.openxmlformats-officedocument.wordprocessingml.document'].includes(contentType) ? 'docx':['application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'].includes(contentType) ? 'xlsx':['application/vnd.ms-excel'].includes(contentType) ? 'xls':['application/vnd.openxmlformats-officedocument.presentationml.presentation'].includes(contentType) ? 'pptx':['application/zip'].includes(contentType) ? 'zip':'';return type
}

http://www.shuangfujiaoyu.com/news/32644.html

相关文章:

  • 网站logo是什么seo服务 文库
  • 做app还要做网站么搜索引擎下载
  • 怎么做网站 白seo网站免费优化软件
  • 商务网站建设课程seo属于运营还是技术
  • 陶瓷网站建设最近实时热点新闻事件
  • 哪个网站可以做思维导图seo值怎么提高
  • 毕业论文美食网站开发友情链接怎么互换
  • node框架做网站防疫管控优化措施
  • 做3d图的网站有哪些软件下载资源网
  • 网站开发人员 工资网络营销课程大概学什么内容
  • 日本可以做的h游戏视频网站seo搜索引擎优化是什么意思
  • 深圳美容网站建设长尾关键词搜索
  • wordpress 空间 域名seo服务商技术好的公司
  • 网站备案抽查通过收录优美图片
  • 河北手机版建站系统开发seo价格是多少
  • wordpress自定义作者湖南关键词优化品牌价格
  • 做机械网站公司建官网要多少钱
  • 基层建设期刊上什么网站查询文章个人网页怎么制作
  • 做网站公司介绍ppt网络推广方案设计
  • 提供免费网站建设百度快照推广效果怎样
  • 做网站用不用云服务器重庆网站制作公司
  • 室内设计师证报名入口官网seo是谁
  • 澳门赌网站怎么做代理seo有哪些网站
  • 网站开发方式有外包公司关键词seo
  • 有谁知道知乎网站是谁做的什么是网络推广营销
  • 网站 留言 以邮件形式广告推广平台
  • 网页和网站设计今日头条国际军事新闻
  • 做新闻微网站有哪些方面搜索引擎关键词排名
  • 深圳市网站建设公司设计信阳网站推广公司
  • 网站需要公安备案吗宿迁网站建设制作