zoukankan      html  css  js  c++  java
  • 12篇学通C#网络编程——第三篇 HTTP应用编程(下)

    第三篇来的好晚啊,上一篇说了如何向服务器推送信息,这一篇我们看看如何"快好准"的从服务器下拉信息。

        网络上有很多大资源文件,比如供人下载的zip包,电影(你懂的),那么我们如何快速的进行下载,大家第一反应肯定就是多线程下载,

    那么这些东西是如何做的呢?首先我们可以从“QQ的中转站里面拉一个rar下来“。

    然后用fiddler监视一下,我们会发现一个有趣的现象:

    第一:7.62*1024*1024≈7990914  千真万确是此文件

    第二:我明明是一个http链接,tmd的怎么变成n多个了?有意思。

    好,我们继续往下看,看看这些链接都做了些什么?

    最终,我们发现http协议中有一个Conent—Range字段,能够把我们的文件总大小进行切分,然后并行下载,最后再进行合并,大概我们知道

    了什么原理,那么,我们强大的C#类库提供了AddRange来获取Http中资源的指定范围。

    既然进行了切分,那么首先一定要知道文件的ContentLength是多少,如果对http协议比较熟悉的话,当发送一个头信息过去,服务器返回的

    头信息中会包含很多东西,此时我们就知道要下载资源的大概情况,这个就有点“兵马未动,粮草先行“的感觉。

    var request = (HttpWebRequest)HttpWebRequest.Create(url);
     
                 request.Method = "Head";
     
                 request.Timeout = 3000;
     
                 var response = (HttpWebResponse)request.GetResponse();
     
                 var code = response.StatusCode;
     
                 if (code != HttpStatusCode.OK)
                 {
                     Console.WriteLine("下载资源无效!");
                     return;
                 }
     
                 var total = response.ContentLength;

    这里有个决策,到底是以下载量来决定线程数,还是以线程数来决定下载量,由于我们的下载取决于当前的网速,所以在这种场合下更好的方案是

    采用后者,这几天在闪存里面两次看到苍老师,肃然起敬,所以决定在不用线程和线程的情况下,看看下载仓老师的速度如何。

    图片大小(217.27KB)

    View Code

          在下面的图中可以看出,我们的资源被分成了n段,在217.27KB的情况下,多线程加速还不是很明显,我们可以试试更大的文件,这里我就

    在本地放一个133M的rar文件。

            //请求文件         public static string url = "http://localhost:56933/1.rar";

    现在看一下效果是非常明显的。

    转自:

    http://www.cnblogs.com/huangxincheng/archive/2012/05/20/2509715.html

  • 相关阅读:
    绑定方法、非绑定方法与静态方法
    封装、隐藏和property装饰器
    自己动手写中文分词解析器完整教程,并对出现的问题进行探讨和解决(附完整c#代码和相关dll文件、txt文件下载)
    SASS -- 基本认识
    网易新闻页面信息抓取 -- htmlagilitypack搭配scrapysharp
    爬虫技术(四)-- 简单爬虫抓取示例(附c#代码)
    c# -- 读取文件夹中的所有文件(备忘)
    爬虫技术(五)-- 模拟简单浏览器(附c#代码)
    爬虫技术(六)-- 使用HtmlAgilityPack获取页面链接(附c#代码及插件下载)
    关于引用mshtml的问题
  • 原文地址:https://www.cnblogs.com/bicabo/p/2652537.html
Copyright © 2011-2022 走看看