文件上传之断点续传方案

简介: 原文 http://www.cnblogs.com/peaceli/archive/2011/04/06/breakpoint_upload.html 和前一篇一样,还是文件上传,这篇主要是文件的断点续传,因为项目中的实际应用情况,需要系统支持断点续传,很多时候用户上传比较大的图档文件往往 一个压缩包的文件就达到了一个多G,有时候网速慢,传到中途卡住了或断线了,又得重新传。

原文 http://www.cnblogs.com/peaceli/archive/2011/04/06/breakpoint_upload.html

和前一篇一样,还是文件上传,这篇主要是文件的断点续传,因为项目中的实际应用情况,需要系统支持断点续传,很多时候用户上传比较大的图档文件往往 一个压缩包的文件就达到了一个多G,有时候网速慢,传到中途卡住了或断线了,又得重新传。这时候让系统支持断点续传还是非常有必要的,起初原本打算用 flex+ftp实现断点续传,后来在园子里看到Jon.Hong写的一篇断点续传的文章,是用silverlight+wcf开发的,觉得更适合在项目中应用(http://www.cnblogs.com/T-MAC/archive/2008/10/20/1298179.html),非常感谢Jon.Hong兄弟。

   这里主要对Jon.Hong的那个项目做了个别地方的修改,刚开始下载无法运行,可能是SilverLight版本的原因,我安装的运行版本是

   重新做了修改才正常运行,另外对其中个别地方逻辑进行了修正,所有调整的内容如下:

      (注:红色部分为后来更新部分——更新时间2011年7月)

   一、原有系统System.Windows.Controls.FileDialogFileInfo 采用了System.IO.FileInfo代替,不然编译不通过,这点明显是版本原因。

   二、进度条无法显示问题。这点也有可能是版本问题,直接用ProgressBar代替原有继承自Jon_UI_Controls的控件后正常显示。

   三、选择文件后不刷新页面再次选择文件画布重叠问题。每次选择文件后清空上传选择文件遗留的画面即可。

    UIElement ui_old = null;

复制代码
 var dialog  =   new  System.Windows.Controls.OpenFileDialog();
            
if  (dialog.ShowDialog()  ==   true )
            {
                
if  (ui_old  !=   null )
                {
                    
this .LayoutRoot.Children.Remove(ui_old);  // 移除原有的画面
                }
                var ui 
=   new  Jon.FileUpLoad.UI.FileUpLoadTaskManager(dialog.File,  " http://localhost:9999/Service1.svc " )
                {
                    Width 
=   400 ,
                    HorizontalAlignment 
=  HorizontalAlignment.Center,
                    VerticalAlignment 
=  VerticalAlignment.Center
                };
                
this .LayoutRoot.Children.Add(ui);
                ui_old 
=  ui;
            }
复制代码

     四、点击上传后,中止按钮无效问题。这点我看了下其中的代码,好像有一个逻辑问题没处理好,原来系统中点中止时把文件流给清空了,这么一来上传是停止了同 时也会引发对象为空的异常,最重要的再次点上传上也是无法继续的,因为此时的文件流为空,无法从断点处继续上传了。为此我定义了一个中止属性,当点击中止 和上传时都会该属性赋值,在引发上传事件时对该属性进行判断即可,并不清空文件流,只有在文件上传完毕后才清空文件流。

    

复制代码
  ///   <summary>
        
///  中止文件上传
        
///   </summary>
         public   void  Abort()
        {
            FileUpLoad.IsAbort 
=   true // 中止标志
            
// this.Dispose();
        }
        
#endregion

        
#region  Protected Methods
        
///   <summary>
        
///  释放资源
        
///   </summary>
         protected   virtual   void  CloseFileStream()
        {
            
if  (fs  !=   null )
            {
                fs.Close();
                fs.Dispose();
                fs 
=   null ;
            }
        }
        
#endregion

        
#region  IDisposable Members
        
///   <summary>
        
///  释放资源
        
///   </summary>
         public   void  Dispose()
        {
            
this .CloseFileStream();
            
this .FileInfo  =   null ;
        }
复制代码

    

    五、增加了上传大小动态显示和百分比进度显示。(其实这里还可以根据已知条件计算上传速率和上传所需要的时间,都是可以实现的)

    六、增加了接收来自aspx页面传递的参数功能。因为基本上要应用到实际项目中,不可避免的要接收外部参数,silverlight接收 aspx页面的参数操作也简单,如下在silverlight页面的page_load方法里加上下面这段即可(这里假设传递的是ID和Name两个参 数)

    

复制代码
 IDictionary < String, String >  paras  =  HtmlPage.Document.QueryString;
            
if  (paras.Count  >   0 )
            {
                
if  (paras.ContainsKey( " ID " ))
                    
this .lblParam.Text  =  paras[ " ID " ];
                
if  (paras.ContainsKey( " Name " ))
                
this .lblParam.Text  +=  paras[ " Name " ];
            }
复制代码

       主要作了以上六处调整,另外如果是在发布后结合到项目中去用,有两点要注意(如果发布后运行有问题的话)

         更新补充部分调整如下:

       七、增加了数据库持久化通讯支持,主要记录是登录用户上传自己的文件,不同用户 上传同一文件时不冲突,上传完成前临时文件的命名为原始文件名+.up用户ID,示例demo是基于数据库配置的,如果要应用的项目中,数据库操作部分自 行修改即可,主要涉及两个方法的修改BeginUpLoad和CheckFileIsUpLoaded。

 

       八、增加了文件上传速率和剩余时间的效果,上传速率是每秒动态计算,比如上传文件流每次(不是每秒)读取2M,有可能每秒读取4次,那么当前的速率为 8M/S,剩余时间的计算用总的未上传的文件大小除以当前速率计算的结果,每秒的速率变化剩余时间也会相应变化。另外界面稍微调整了下颜色,美感不怎么 样,先这么凑活了:)如下图:

          

   一、系统权限问题,参考了网上的解决方法,系统盘的windows下的temp文件夹权限设置,操作如下:

    

 

    

    

    二、部署的站点属性设置。主要是对MIME类型的设置,即添加支持对silverlight运行识别的扩张类型,如下:

    

    

    运行的效果图如下:

    

    

    

    

 

    下面这张截图是接收参数和输出参数显示

    

 

    总体来说这个断点续传的功能还是相当不错的,上传时的运行效率也很高,可以设置每次(不是每秒)上传循环时读取文件流的大小,我测试设置的时每次2M,如果网速好的话就非常快了。

    详细的参考内容大家可以参考Jon.Hong的相关文件,里面的代码我这里并没有做过多详细的说明。下面是我修改后的项目源码:

   

    源码下载断点续传

         新版本源码下载:断点续传新版

   OK,两篇都是文件上传的,算是写完了,好久没上来写写什么了,有空了写写东西感觉也还好的,至少不坏,就当是消磨时间吧,分享给大家也当是相互学习了,再次感谢Jon.Hong兄弟。

目录
相关文章
|
2月前
|
Web App开发 存储 移动开发
大文件上传实现方式比较
大文件上传实现方式比较
45 5
|
2月前
|
Java C#
断点续传(上传)C#版
断点续传(上传)C#版
30 0
|
5月前
|
前端开发 NoSQL Redis
如何实现大文件上传:秒传、断点续传、分片上传
如何实现大文件上传:秒传、断点续传、分片上传
383 0
|
5月前
大文件上传如何断点续传
该文档描述了一个大文件上传流程,包括:1) 文件分片,2) 计算文件及分片的Hash值以生成唯一标识符,3) 上传分片并检查已上传状态以避免重复,4) 在上传中断时能恢复,5) 服务端合并分片成原始文件,6) 错误处理(如网络中断、服务器故障、上传失败等)并通知用户,最后7) 返回上传成功信息。
|
存储 前端开发 C#
如何实现文件断点续传功能
相信大家都使用过迅雷、电驴、百度云网盘等一类的工具,所有这些支持上传或下载的工具都有一个功能,那就是断点续传,也就是在你网络不佳传输断开时,传输会暂停,在网络恢复后,可以继续传输,从而避免数据的重复上传,以减少网络流量,提高效率。那么,你有仔细想过这其中的实现原理嘛?
|
存储 前端开发 NoSQL
注册java实现文件分片上传并且断点续传
一、简单的分片上传 针对第一个问题,如果文件过大,上传到一半断开了,若重新开始上传的话,会很消耗时间,并且你也并不知道距离上次断开时,已经上传到哪一部分了。因此我们应该先对大文件进行分片处理,防止上面提到的问题。
|
监控 UED
大文件上传如何做断点续传
大文件上传如何做断点续传
273 0
|
前端开发 关系型数据库 MySQL
大文件上传
大文件上传
160 0
|
存储 前端开发 NoSQL
java实现文件分片上传并且断点续传
针对第一个问题,如果文件过大,上传到一半断开了,若重新开始上传的话,会很消耗时间,并且你也并不知道距离上次断开时,已经上传到哪一部分了。因此我们应该先对大文件进行分片处理,防止上面提到的问题。
347 0
|
缓存 CDN
U3D客户端框架之支持断点续传的文件下载器实现方案
文件下载器是应用程序的基础模块,为应用程序与外部网络交互提供了必要的桥梁。该模块设计初衷是为了热更新过程中,下载CDN站点上的文件资源,所以下载器会验证 要下载的文件是否存在于CDN中。如果存在允许下载器继续工作;如果不存在会跳过本地下载。做这层检测是为了安全性考虑,不允许随意下载网络资源。如果有需求可以跳过这层检测。