Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304416
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站网址导航名站网址导航小编为爱好网页hTML5的朋友提供关于网页hTML5的相关知识。

  • 本篇文章的具体介绍如下
大相关站点文件分块

一般常用的web服务器都有对向服务器端提交数据有大小限制。超过一定大小相关站点文件服务器端将返回拒绝信息。当然,web服务器都提供了配置相关站点文件可能修改限制的大小。针对iis实现大相关站点文件的上传网上也有一些通过修改web服务器限制相关站点文件大小来实现。不过这样对web服务器的安全带了问题。攻击者很容易发一个大数据包,将您的web服务器直接给拖死。
现在针对大相关站点文件上传主流的实现方式,通过将大相关站点文件分块。比如针对一个100M相关站点文件,按2M拆分为50块。然后再将每块相关站点文件依次上传到服务器上,上传完成后再在服务器上合并相关站点文件。
在web实现大相关站点文件上传,核心主要实现相关站点文件的分块。在html5 File API 出现以前,要想在web上实现相关站点文件分块传输。只有通过flash或Activex实现相关站点文件的分块。

在html5 下,咱们可以直接通过file的slice 实用具体的方法来实现相关站点文件的分块。如:

XML/网页hTML Code 复制内容到剪贴板
  1. file.slice(0,1000);    
  2. file.slice(1000,2000);    
  3. file.slice(2000,3000);  
然后再通过XMLhttpRequest异步上传到服务器。

html5 上传相关站点文件类库

如果您有兴趣及时间 ,当然可以自己用html5的File API来实现。本人在网上查找到了以下两个支持html5类库。
resumable.js 附git上的地址:https://github.com/23/resumable.js
Pludload http://plupload.com/

resumable是一个纯html5上传类库。
而Pludload是一个支持html5,flash,silverlight,html4,它会自动判断浏览是否支持html5不支持将用其它的上传方式。
我测试下来,resumable和Pludload都支持html5分块上传相关站点文件。用下来觉得resumable比较适合,以下就选resumable来进行介绍。

resumable.js断点上传使用介绍

主要配置介绍:
JavaScript Code 复制内容到剪贴板
  1. var r = new Resumable({   
  2.             target:'/test/upload',   
  3.             chunkSize:1*1024*1024,   
  4.             simultaneousUploads:4,   
  5.             testChunks: true,   
  6.             throttleProgressCallbacks:1,   
  7.             method: "octet"  
  8.           });  
chunkSize 分块相关站点文件大小,以字节为单位
simultaneousUploads 同时上传相关站点文件块的进程数,可以同时允许多个相关站点文件块上传。
testChunks 上前相关站点文件块是否先通过get方式发送相关站点文件信息检测相关站点文件是否已经上传。

resumable断点上传是通过testChunks配置节点来实现,当设置为true时。resumable会先发送一个get请求,如果http状态返回 200。则认为当前块已经上传完成,然后进行下一块的get请求。如果http状态返回的不是200,则将通过post方式发送当前块数据包进行相关站点文件块上传。

设置testChunks为true每次上传都会增加一个get请求,如果咱们已经知道上次中断上传前相关站点文件的块数。下次直接从中断的块数上传就行了。这样可以为每个块减少一次http的get请求。
针对这个需求,我修改了resumable的源码,为resumable里的file对象增加了一个startchunkindex的属性,默认为0。用于设置当前相关站点文件从哪一个块开始上传。这样,咱们只需要在在相关站点文件上传前从服务器上进行一次查询(查询当前相关站点文件上传到哪一块),返回上次上传的相关站点文件块索引。再将索引值设置到file的startchunkindex属性就可以实现从上次断开的相关站点文件块开始上传。
相关调用方式:

JavaScript Code 复制内容到剪贴板
  1. // handle file add event   
  2.               r.on('fileAdded'function (file) {   
  3.                   file.startchunkindex = 0; // 设置当前相关站点文件开始上传的块数  
具体可以查看附件里的demo。

收尾工作

所有相关站点文件块上传完,最后工作就是合并保存相关站点文件。附件为resumable断上传.net实现的服务端例子,包括简单的相关站点文件合并功能。其它语言的demo大家也可以从resumable的git上下载。
demo例子为了简单,只是把相关站点文件存放在本机。在真实的生产环境中。一般应该放在单独的相关站点文件服务器上(前台web通过ftp或相关站点文件夹共享方式上传到相关站点文件服务器),然后对上传好的相关站点文件进行分发镜像或处理(比如视频压缩)。当然最好是存在分布式相关站点文件系统中,目前看下来放到hadoop分布式相关站点文件系统(hDFS)是一个不错的好方案。

demo

Vs2012 html5 Upload demo下载

,html5,大相关站点文件,断点续传

分享到:

  admin

注册时间:

网站:0 个   APP:3 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304416

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市