最近研究了一下IE自带的一些Activex控件,可以比较简单的实现断点续传功能

不过这种方式不推荐,因为安全性较低,而且需要修改客户端注册表,调低ie安全配置

还有就是我比较懒,只打算写个思路和几个关键的api功能

断点续传的基本思路如下:

1、客户端计算文件md5值,发送到服务器端校验;

2、服务器端根据客户端发送过来的md5值来确定文件是否存在,并返回文件大小,这样可以确定断点续传的文件开始位置;

3、客户端根据服务器返回的文件开始位置,开始读取文件块,每读取一块就发送给服务器,发送成功则读取下一块;

启用ie的ADODB.Stream

读取文件可以用ADODB.Stream,支持文件指针,可以从指定位置开始读取文件

但是使用的话,需要先修改注册表,找到HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\ActiveX Compatibility\{00000566-0000-0010-8000-00AA006D2EA4}

在右窗格中,双击“Compatibility Flags”,在“编辑 DWORD 值”对话框中,确保选中“十六进制”选项,在“数值数据”框中键入 0,然后单击“确定”。

读取文件计算md5

计算文件可以用CAPICOM.HashedData,如果文件太大可以分次读取,挺简单的,直接上代码

		function getMD5(){
var stream = new ActiveXObject("ADODB.Stream");
var hashed = new ActiveXObject("CAPICOM.HashedData");
if (stream == null || hashed == null){
alert("not support");
}
else{
hashed.Algorithm = 3;//hash类型MD5
stream.Type = 1;//指定读取方式为二进制
stream.Open();
stream.LoadFromFile("E:\\TDownloads\\Http.rar");
stream.Position = 0;//读取文件的位置
var filesize = stream.Size;//文件大小
var blocksize = 10240;//读取块大小
var readCount = 0;//读取计数
var totalCount = Math.ceil(filesize/blocksize);//总共需要读取的次数
for (var i=0;i<totalCount;i++){
hashed.Hash(stream.Read(blocksize));
}
stream.Close();
alert("MD5=" + hashed.Value);
}
}

stream.Read(blocksize)是每次读取blocksize大小的二进制数据,stream.Read()将一次性全部读取出来

发送文件碎片

现在客户端可以读取文件碎片,也可以计算md5了,就差异步发送文件碎片了

可以使用Msxml2.XMLHTTP发送二进制数据,js本身不支持发送二进制数据

如果一定要用js来发送文件碎片的话,可以变通的把二进制转换成base64字符串,然后服务器端再解密一次

		function sendData(){
...
var data = stream.Read(blocksize);//读取出文件碎片
...
var xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
//这里的具体url可以自己定义
xmlhttp.Open("POST","uploadfile?filename=Http.rar&position=0&blocksize=10240&md5=md5",false);
xmlhttp.setRequestHeader("Content-Length",blocksize);
xmlhttp.send(data);//发送的二进制数据
alert(xmlhttp.responseText);//回执
}

以java为例,在服务器端接收的时候,url中的参数可以如下获取

String filename = req.getParameter("filename");

二进制数据可以直接以流的方式获取

HttpServletRequest.getInputStream();

就当抛砖引玉了~

IE下使用ADODB.Stream实现断点续传的更多相关文章

  1. 解决:ADODB.Stream 错误 '800a0bbc' 写入文件失败

    重装更改目录为e盘后,上传文件出现问题.解决方法: 调用adodb.stream的savetofile方法时发生错误, ADODB.Stream 错误 800a0bbc 写入文件失败.(msxml3. ...

  2. ADODB.Stream

    读写文本文件时出现了乱码,找到了ADODB.Stream,可以指定字符集读取文本 Function ReadUTF() Filename = "F:\vba\2018 - new\2018- ...

  3. asp上传图片提示 ADODB.Stream 错误 '800a0bbc'的解决方法

    asp上传图片提示 ADODB.Stream 错误 '800a0bbc' 有这个提示有很多问题导致.权限是常见一种.这个不多说,还有一个有点怪的就是 windows2008显示系统时间的格式竟然是:2 ...

  4. asp adodb.stream读取文件和写文件

    读取文件操作: '------------------------------------------------- '函数名称:ReadTextFile '作用:利用AdoDb.Stream对象来读 ...

  5. ASP 读写文件FSO,adodb.stream

    例如静态化页面的时候 总结:用server.CreateObject("adodb.stream") 来读写比较好,可避免乱码和读取到多余的字符.....不推荐 "scr ...

  6. wcf stream 不知道长度的情况下,读取stream

    http://bbs.csdn.net/topics/360163784 string filepath = @"http://ww4.sinaimg.cn/thumbnail/6741e0 ...

  7. adodb.stream对象的方法/属性

    Cancel 方法      使用方法如下      Object.Cancel      说明:取消执行挂起的异步 Execute 或 Open 方法的调用.Close   方法      使用方法 ...

  8. 文件上传下下载(不包含断点续传) Excel,Word导入导出基础

    1.文件上传下载(MVC应用) 视图:form表单,编码方式为multipart/form-data <body> <div> <form action="/D ...

  9. ADODB.Stream在进行文件上传时报错

    最近在做web项目,有个控件是上传材料文件和文件夹,本地运行正常,放到服务器上,一直报错:AutoRuntime服务器无法创建..... 解决方法: 1.配置ie浏览器的安全级别 2.修改ie浏览器对 ...

随机推荐

  1. aop aspect

    所以“<aop:aspect>”实际上是定义横切逻辑,就是在连接点上做什么,“<aop:advisor>”则定义了在哪些连接点应用什么<aop:aspect>.Sp ...

  2. SPRING IN ACTION 第4版笔记-第九章Securing web applications-004-对密码加密passwordEncoder

    一. 1.Focusing on the authentication query, you can see that user passwords are expected to be stored ...

  3. 提供几个可注册的edu邮箱链接

    旧版的邮箱大全有edu邮箱的专题页面,放出来2个国内edu.cn邮箱的注册地址:@live.shop.edu.cn和@abc.shop.edu.cn,现在已经停止开放注册了. 其实旧版中还做了个隐藏的 ...

  4. HTTP代理协议 HTTP/1.1的CONNECT方法

    我们平时使用HTTP协议无非就是GET.POST这些方法,但是HTTP的内容远不止那些.今天就来说说HTTP代理使用的CONNECT.这个不是在网页开发上用的,如果没兴趣就跳过吧. APACHE只是作 ...

  5. Android 通过 Intent 传递类对象

    Android中Intent传递类对象提供了两种方式一种是 通过实现Serializable接口传递对象,一种是通过实现Parcelable接口传递对象. 要求被传递的对象必须实现上述2种接口中的一种 ...

  6. JDK个目录,以及与环境变量的关系

    最近学习过程中老是看JDK里面的东西,可每次都翻书找,找了又忘.JDK,我们今天来个了断吧........ 一:bin: JDK中所包含的开发工具的可执行文件,PATH环境变量应该包含一个指向此目录的 ...

  7. R语言学习笔记:取数据子集

    上文介绍了,如何生成序列,本文介绍一下如何取出其数据子集 取出元素的逻辑值 > x<-c(0,-3,4,-1,45,90,5) > x>0 [1] FALSE FALSE  T ...

  8. Oracle中Blob和Clob类型的区别与操作

    Oracle中Blob和Clob类型 1.Oracle中Blob和Clob类型的区别 BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的 ...

  9. Excel 内容粘贴到DataGridView, DataGridView 粘贴到 Excel

    void dataGridView1_KeyDown(object sender, KeyEventArgs e) { if (e.Control && e.KeyCode == Ke ...

  10. 【jsonp】

    function handleResponse(response) { alert("You’re at IP address " + response.ip + ", ...