zoukankan      html  css  js  c++  java
  • HttpClient 上传/下载文件计算文件传输进度

     1.使用ProgressMessageHandler 获取进度

    using namespace System.Net.Http;
    
    
    
    HttpClientHandler hand = new HttpClientHandler();
    ProgressMessageHandler processMessageHander = new ProgressMessageHandler(hand);
    HttpClient localHttpClient = new HttpClient(processMessageHander);
    
    
    
    processMessageHander.HttpSendProgress += (sender, e2) =>
    {
        int num = e2.ProgressPercentage; //you can use HttpProgressEventArgs e 
        worker.ReportProgress(num);
    };

    
    

      var resp = await localHttpClient.SendAsync(httpRequestMessage);
      Stream stream = await resp.Content.ReadAsStreamAsync();

     2. 在已知要下载的文件大小的情况下,可以计算获取进度

    var resp = await _client.SendAsync(request, HttpCompletionOption.ResponseHeadersRead);
    using (Stream stream = await resp.Content.ReadAsStreamAsync(),
            fs = new FileStream(downloadPath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite, 10240, true))
    {
        var totalRead = 0L;
        var buffer = new byte[10240];
        var isMoreToRead = true;
        do
        {
            if (worker.CancellationPending)
            {
                e.Cancel = true;
                return false;
            }
    
            var read = await stream.ReadAsync(buffer, 0, buffer.Length);
            if (read == 0)
            {
                isMoreToRead = false;
            }
            else
            {
                await fs.WriteAsync(buffer, 0, read);
                totalRead += read;
               
                int percentComplete = (int)((float)totalRead / (float)fileSize * 100);
                worker.ReportProgress(percentComplete);
            }
        }
        while (isMoreToRead);
    }
  • 相关阅读:
    js 中添加空格
    js radio 赋值取值
    对于不返回任何键列信息的 selectcommand 不支持 updatecommand 的动态 sql 生成
    Adapter
    MySQL学习笔记:while循环
    GIS数据资源下载
    观察者模式与发布订阅模式
    Cesium局部区域精细瓦片数据下载技巧
    Cesium加载地形数据只显示半个地球
    git教程和命令集合
  • 原文地址:https://www.cnblogs.com/wswind/p/9177853.html
Copyright © 2011-2022 走看看