使用.NET实现断点续传

转载 2007年10月12日 15:06:00
使用.NET实现断点续传  
  断点续传的原理  
  在了解HTTP断点续传的原理之前,先来说说HTTP协议,HTTP协议是一种基于tcp的简单协议,分为请求和回复两种。请求协议是由客户机(浏览器) 向服务器(WEB   SERVER)提交请求时发送报文的协议。回复协议是由服务器(web   server),向客户机(浏览器)回复报文时的协议。请求和回复协议都由头和体组成。头和体之间以一行空行为分隔。  
    以下是一个请求报文与相应的回复报文的例子:  
  GET   /image/index_r4_c1.jpg   HTTP/1.1  
  Accept:   */*  
  Referer:   http://192.168.3.120:8080  
  Accept-Language:   zh-cn  
  Accept-Encoding:   gzip,   deflate  
  User-Agent:   Mozilla/4.0   (compatible;   MSIE   6.0;   Windows   NT   5.0;   .NET   CLR   1.0.3705)  
  Host:   192.168.3.120:8080  
  Connection:   Keep-Alive  
       
  HTTP/1.1   200   OK  
  Server:   Microsoft-IIS/5.0  
  Date:   Tue,   24   Jun   2003   05:39:40   GMT  
  Content-Type:   image/jpeg  
  Accept-Ranges:   bytes  
  Last-Modified:   Thu,   23   May   2002   03:05:40   GMT  
  ETag:   "bec48eb862c21:934"  
  Content-Length:   2827  
    ?   JFIF     H   H        C   [1]  
  ….  
     
  下面我们就来说说“断点续传”。  
  顾名思义,断点续传就是在上一次下载时断开的位置开始继续下载。在HTTP协议中,可以在请求报文头中加入Range段,来表示客户机希望从何处继续下载。  
  比如说从第1024字节开始下载,请求报文如下:  
    GET   /image/index_r4_c1.jpg   HTTP/1.1  
  Accept:   */*  
  Referer:   http://192.168.3.120:8080  
  Accept-Language:   zh-cn  
  Accept-Encoding:   gzip,   deflate  
  User-Agent:   Mozilla/4.0   (compatible;   MSIE   6.0;   Windows   NT   5.0;   .NET   CLR   1.0.3705)  
  Host:   192.168.3.120:8080  
  Range:bytes=1024-  
  Connection:   Keep-Alive  
    .NET中的相关类  
  明白了上面的原理,那么,我们来看看.NET   FRAMEWORK中为我们提供了哪些类可以来做这些事。  
  完成HTTP请求  
  System.Net.HttpWebRequest  
  HttpWebRequest   类对   WebRequest   中定义的属性和方法提供支持,也对使用户能够直接与使用   HTTP   的服务器交互的附加属性和方法提供支持。  
  HttpWebRequest   将发送到   Internet   资源的公共   HTTP   标头值公开为属性,由方法或系统设置。下表包含完整列表。可以将   Headers   属性中的其他标头设置为名称/值对。但是注意,某些公共标头被视为受限制的,它们或者直接由   API公开,或者受到系统保护,不能被更改。Range也属于被保护之列,不过,.NET为开发者提供了更方便的操作,就是   AddRange方法,向请求添加从请求数据的开始处或结束处的特定范围的字节范围标头  
  完成文件访问  
  System.IO.FileStream  
  FileStream   对象支持使用Seek方法对文件进行随机访问,   Seek   允许将读取/写入位置移动到文件中的任意位置。这是通过字节偏移参考点参数完成的。字节偏移量是相对于查找参考点而言的,该参考点可以是基础文件的开始、 当前位置或结尾,分别由SeekOrigin类的三个属性表示。  
    代码实现  
  了解了.NET提供的相关的类,那么,我们就可以方便的实现了。  
  代码如下:  
     
  static   void   Main(string[]   args)  
                              {  
                                             
                                            string   StrFileName="c://aa.zip";             //根据实际情况设置  
                                            string   StrUrl="http://www.xxxx.cn/xxxxx.zip";       //根据实际情况设置  
     
                                            //打开上次下载的文件或新建文件  
                                            long   lStartPos   =0;  
                                            System.IO.FileStream   fs;  
                                            if   (System.IO.File.Exists(StrFileName))  
                                            {  
                                                          fs=   System.IO.File.OpenWrite(StrFileName);  
                                                          lStartPos=fs.Length;  
                                                          fs.Seek(lStartPos,System.IO.SeekOrigin.Current);       //移动文件流中的当前指针  
                                            }  
                                            else  
                                            {  
                                                          fs   =   new   System.IO.FileStream(StrFileName,System.IO.FileMode.Create);  
                                                          lStartPos   =0;  
                                            }  
                                             
                                            //打开网络连接  
                                            try  
                                            {  
                                                          System.Net.HttpWebRequest   request   =(System.Net.HttpWebRequest)System.Net.HttpWebRequest.Create(StrUrl);  
                                                          if   (   lStartPos>0)  
                                                                        request.AddRange((int)lStartPos);         //设置Range值  
                                                           
                                                          //向服务器请求,获得服务器回应数据流  
                                                          System.IO.Stream   ns=   request.GetResponse().GetResponseStream();  
     
                                                          byte[]   nbytes   =   new   byte[512];  
                                                          int   nReadSize=0;  
                                                          nReadSize=ns.Read(nbytes,0,512);  
                                                          while(   nReadSize   >0)  
                                                          {  
                                                                        fs.Write(nbytes,0,nReadSize);  
                                                                        nReadSize=ns.Read(nbytes,0,512);  
                                                          }  
                                                          fs.Close();  
                                                          ns.Close();  
                                                          Console.WriteLine("下载完成");  
                                            }  
                                            catch(Exception   ex)  
                                            {  
                                                          fs.Close();  
                                                          Console.WriteLine("下载过程中出现错误:"+ex.ToString());  
                                            }  
                              }  
  

C# 断点续传原理与实现

在了解HTTP断点续传的原理之前,让我们先来了解一下HTTP协议,HTTP协议是一种基于tcp的简单协议,分为请求和回复两种。请求协议是由 客户机(浏览器)向服务器(WEB SERVER)提交请求时发...
  • m290345792
  • m290345792
  • 2015年09月10日 10:16
  • 2827

使用.NET实现断点续传

断点续传的原理 在了解HTTP断点续传的原理之前,先来说说HTTP协议,HTTP协议是一种基于tcp的简单协议,分为请求和回复两种。请求协议是由客户机(浏览器)向服务器(WEB SERVER)提交请...
  • zlwzlwzlw
  • zlwzlwzlw
  • 2015年02月09日 16:12
  • 478

多线程下载文件和断点续传的简单实现

断点续传的要点: 每写入一次文件就将这次写入文件的位置保存起来(保存到文件中),下次读取文件的的位置开始下载public class MuchThreadDown { p...
  • wo_ha
  • wo_ha
  • 2016年07月24日 21:05
  • 2823

多线程下载和断点续传和进度条

public class MainActivity extends Activity { protected final int DOWNLOAD_ERROR = 1; private fin...
  • lilengfan1991
  • lilengfan1991
  • 2015年07月02日 11:12
  • 252

关于“多线程断点续传下载”功能的一个简单实现和讲解

转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992     上班第一天,在技术群里面和大家闲扯,无意中谈到了关于框架的使用,一个同学说为了用xUtils的断线...
  • wanglha
  • wanglha
  • 2015年03月13日 12:45
  • 934

使用.NET实现文件断点续传

先来了解断点续传的原理 在了解HTTP断点续传的原理之前,先来说说HTTP协议,HTTP协议是一种基于tcp的简单协议,分为请求和回复两种。请求协议是由客户机(浏览器)向服务器(WEB SERV...
  • chenyq2008
  • chenyq2008
  • 2014年10月27日 22:03
  • 410

一分钟实现多文件断点续传——断点续传框架

本人先前的博客有对多文件分段断点续传的功能进行详细的介绍,如果你有兴趣可以先阅读Android多文件断点续传(一)——数据封装以及界面实现。本人在先前的基础上对代码进行了封装,本帖主要介绍如何集成封装...
  • a1533588867
  • a1533588867
  • 2016年11月16日 17:30
  • 1480

Android之——多线程断点续传下载示例

在上一篇博文中,我们讲解了如何实现Android的多线程下载功能,通过将整个文件分成多个数据块,开启多个线程,让每个线程分别下载一个相应的数据块来实现多线程下载的功能。多线程下载中,可以将下载这个耗时...
  • l1028386804
  • l1028386804
  • 2015年07月15日 21:02
  • 2910

使用xUtils框架实现多线程下载和断点续传

在前面的博客中分别介绍了在Java中实现多线程下载和断点续传以及在android中实现多线程下载和断点续传,这篇博客将介绍使用第三方框架xUtils实现多线程下载和断点续传 首先看一下实现的效果,点...
  • u010105970
  • u010105970
  • 2016年04月23日 17:26
  • 2783

HTTP协议 断点续传

要实现断点续传的功能,通常都需要客户端记录下当前的下载进度,并在需要续传的时候通知服务端本次需要下载的内容片段。 HTTP1.1协议(RFC2616)中定义了断点续传相关的HTTP头 Range...
  • pastebin
  • pastebin
  • 2014年05月09日 20:35
  • 706
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用.NET实现断点续传
举报原因:
原因补充:

(最多只允许输入30个字)