IE下使用ADODB.Stream实现断点续传
最近研究了一下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实现断点续传的更多相关文章
- 解决:ADODB.Stream 错误 '800a0bbc' 写入文件失败
重装更改目录为e盘后,上传文件出现问题.解决方法: 调用adodb.stream的savetofile方法时发生错误, ADODB.Stream 错误 800a0bbc 写入文件失败.(msxml3. ...
- ADODB.Stream
读写文本文件时出现了乱码,找到了ADODB.Stream,可以指定字符集读取文本 Function ReadUTF() Filename = "F:\vba\2018 - new\2018- ...
- asp上传图片提示 ADODB.Stream 错误 '800a0bbc'的解决方法
asp上传图片提示 ADODB.Stream 错误 '800a0bbc' 有这个提示有很多问题导致.权限是常见一种.这个不多说,还有一个有点怪的就是 windows2008显示系统时间的格式竟然是:2 ...
- asp adodb.stream读取文件和写文件
读取文件操作: '------------------------------------------------- '函数名称:ReadTextFile '作用:利用AdoDb.Stream对象来读 ...
- ASP 读写文件FSO,adodb.stream
例如静态化页面的时候 总结:用server.CreateObject("adodb.stream") 来读写比较好,可避免乱码和读取到多余的字符.....不推荐 "scr ...
- wcf stream 不知道长度的情况下,读取stream
http://bbs.csdn.net/topics/360163784 string filepath = @"http://ww4.sinaimg.cn/thumbnail/6741e0 ...
- adodb.stream对象的方法/属性
Cancel 方法 使用方法如下 Object.Cancel 说明:取消执行挂起的异步 Execute 或 Open 方法的调用.Close 方法 使用方法 ...
- 文件上传下下载(不包含断点续传) Excel,Word导入导出基础
1.文件上传下载(MVC应用) 视图:form表单,编码方式为multipart/form-data <body> <div> <form action="/D ...
- ADODB.Stream在进行文件上传时报错
最近在做web项目,有个控件是上传材料文件和文件夹,本地运行正常,放到服务器上,一直报错:AutoRuntime服务器无法创建..... 解决方法: 1.配置ie浏览器的安全级别 2.修改ie浏览器对 ...
随机推荐
- aop aspect
所以“<aop:aspect>”实际上是定义横切逻辑,就是在连接点上做什么,“<aop:advisor>”则定义了在哪些连接点应用什么<aop:aspect>.Sp ...
- 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 ...
- 提供几个可注册的edu邮箱链接
旧版的邮箱大全有edu邮箱的专题页面,放出来2个国内edu.cn邮箱的注册地址:@live.shop.edu.cn和@abc.shop.edu.cn,现在已经停止开放注册了. 其实旧版中还做了个隐藏的 ...
- HTTP代理协议 HTTP/1.1的CONNECT方法
我们平时使用HTTP协议无非就是GET.POST这些方法,但是HTTP的内容远不止那些.今天就来说说HTTP代理使用的CONNECT.这个不是在网页开发上用的,如果没兴趣就跳过吧. APACHE只是作 ...
- Android 通过 Intent 传递类对象
Android中Intent传递类对象提供了两种方式一种是 通过实现Serializable接口传递对象,一种是通过实现Parcelable接口传递对象. 要求被传递的对象必须实现上述2种接口中的一种 ...
- JDK个目录,以及与环境变量的关系
最近学习过程中老是看JDK里面的东西,可每次都翻书找,找了又忘.JDK,我们今天来个了断吧........ 一:bin: JDK中所包含的开发工具的可执行文件,PATH环境变量应该包含一个指向此目录的 ...
- R语言学习笔记:取数据子集
上文介绍了,如何生成序列,本文介绍一下如何取出其数据子集 取出元素的逻辑值 > x<-c(0,-3,4,-1,45,90,5) > x>0 [1] FALSE FALSE T ...
- Oracle中Blob和Clob类型的区别与操作
Oracle中Blob和Clob类型 1.Oracle中Blob和Clob类型的区别 BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的 ...
- Excel 内容粘贴到DataGridView, DataGridView 粘贴到 Excel
void dataGridView1_KeyDown(object sender, KeyEventArgs e) { if (e.Control && e.KeyCode == Ke ...
- 【jsonp】
function handleResponse(response) { alert("You’re at IP address " + response.ip + ", ...