对于web下的上传,实际上更多的时候不用上传太大东西,asp.net默认的上传组件足够用了,美中不足就是没有上传进度反映,所以现在要做的就是在asp.net默认的上传基础上加上进度反映。
关于web上传的原理,曾在以前有深入分析过《asp无组件上传进度条解决方案》《Asp无组件上传带进度条(续) 》,并有写过asp版的无组件上传进度条,在这里就不多赘述。相信很多人都看过思归发的《用ASP.NET上传大文件》,解决的方法是利用隐含的HttpWorkerRequest,用它的GetPreloadedEntityBody 和 ReadEntityBody方法从IIS为ASP.NET建立的pipe里分块读取数据,对于每块分块进行分析并存储为临时文件,相对比较复杂。
要实现进度条的实时反映,核心的技术就是对上传的数据进行“分块”读取,在读取每块数据时记录当前已上传的块数,根据分块的大小,即可知道已上传的大小,根据总大小,即可知道当前上传的进度。具体的技术还是利用隐含的HttpWorkerRequest,用它的GetPreloadedEntityBody 和 ReadEntityBody方法从IIS为ASP.NET建立的pipe里分块读取数据,只不过仅仅是分块和记录已上传块数而已,用不着对已上传的数据进行分析和处理,因为这部分复杂的工作已经由asp.net的上传组件给我们做了。
根据上面所述的原理,具体代码相对很简单,我写了一个例子,用一个专门的进度显示页面(Progress.aspx),通过定时刷新(XmlHttp, FF支持)来获取当前上传的进度信息,并实时反映到上传页面上。
代码下载(解压后给web目录设置虚拟目录为“Upload”即可),其中进度条我是用脚本来实现的,单独的进度条脚本代码:
http://www.webuc.net/myproject/progressbar/progressinfo.htm
http://www.webuc.net/myproject/progressbar/progressbar.rar
打印 | 张贴于 2005-06-12 21:35:00 | Tag:Web技术
目前致力于
留言反馈
有些兄弟说:文件上传上了,但是在上传过程中进度条没有显示进度,等上传完毕后才显示进度条。
可能是你上传的文件太小了,你传个100M的试试就能看到效果了。还有就是改动那个setTimeout的internal参数,让它的值变小点,本来是500,你改成100的话就能看到进度条快速的动了。
不过在最后读取完成的时候就变慢了,不知道是不是那行“传入读取的内容”代码吃掉了所有的CPU时间呢。我想在这前面加一个状态,比如:生成文件。但是pressbar.aspx监测不到。
用js应该可以控制吧
行:168
字符:27
错误:未结束的字符串变量
代码:0
请问,这是什么原因呢?我已把charset设为了UTF-8及targetschema设为了IE5了
是不是还的自己写代码呢?
如果上传的文件超过了限制的大小,有没有办法在文件完全上传完之前 中断操作呢?
有些不太完美,有人知道解决方法么?
谢谢。
我的E_M:okokdaikin@21cn.com