c#,.net 下载文件 设置断点

        /// <summary>
        /// c#,.net 下载文件  
        /// </summary>
        /// <param name="URL">下载文件地址</param>
        /// <param name="filename">下载后的存放地址</param>
        /// <param name="prog">用于显示的进度条</param>
        /// <param name="label1"></param>
        public void DownloadFile(string URL, string filename, System.Windows.Forms.ProgressBar prog, System.Windows.Forms.Label label1)
        {
            float percent = 0;
            try
            {
                System.Net.HttpWebRequest Myrq = null, _Myrq = null;
                System.Net.HttpWebResponse myrp = null, _myrp = null;
                #region 是否存在断点并设置断点
                if (File.Exists(filename))//文件是否存在
                {
                    so = new System.IO.FileStream(filename, System.IO.FileMode.Open);//打开文件流
                    downedsize = so.Length;//已下载的大小
                    so.Seek(downedsize, SeekOrigin.Current);//设置流断点
                }
                else
                {
                    so = new System.IO.FileStream(filename, System.IO.FileMode.Create);//创建文件流
                    downedsize = 0;
                }
                #endregion
                #region 设置下载流Range值。
                _Myrq = (System.Net.HttpWebRequest)System.Net.HttpWebRequest.Create(URL);
                _myrp = (System.Net.HttpWebResponse)_Myrq.GetResponse();
                long totalBytes = _myrp.ContentLength;//文件大小值
                if (prog != null)
                {
                    prog.Maximum = (int)totalBytes;
                }
                // “基础连接已经关闭:   无法连接到远程服务器”的错误
                _myrp.Close();
                Myrq = (System.Net.HttpWebRequest)System.Net.HttpWebRequest.Create(URL);
                if (downedsize > 0 && downedsize < totalBytes)
                {
                    Myrq.AddRange((int)downedsize); //设置Range值
                }
                else if (downedsize==totalBytes)
                {
                    so.Close();
                    MessageBox.Show("您已经下载好此文件!", "提示");
                    return;
                }
                myrp = (System.Net.HttpWebResponse)Myrq.GetResponse();//剩余的流
                st = myrp.GetResponseStream();//下载的目标流
                #endregion
                long totalDownloadedByte = downedsize > 0 ? downedsize : 0;
                byte[] by = new byte[1024];
                int osize = st.Read(by, 0, (int)by.Length);
                while (osize > 0)
                {
                    totalDownloadedByte = osize + totalDownloadedByte;
                    System.Windows.Forms.Application.DoEvents();
                    so.Write(by, 0, osize);
                    if (prog != null)
                    {
                        prog.Value = (int)totalDownloadedByte;
                    }
                    osize = st.Read(by, 0, (int)by.Length);
                    percent = (float)totalDownloadedByte / (float)totalBytes * 100;
                    label1.Text = "当前补丁下载进度" + percent.ToString() + "%";
                    System.Windows.Forms.Application.DoEvents(); //必须加注这句代码,否则label1将因为循环执行太快而来不及显示信息
                }
                so.Close();
                st.Close();
                myrp.Close();//关闭流
                MessageBox.Show("下载完毕!","提示");
            }
            catch (System.Exception)
            {
            }
        }

下载例子地址:http://download.csdn.net/detail/yes16ws/4128914

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 实现文件服务器的断点续传功能通常需要考虑以下几个方面: 1. 客户端与服务器之间的文件传输协议。常见的协议有 FTP、SFTP、HTTP 等。其中,HTTP 协议在 Web 开发中应用最为广泛,也比较容易实现。 2. 文件传输的分块处理。这里需要将文件按照固定大小的块进行切分,每个块对应一个标识符,用于记录每个块的传输状态。 3. 传输状态的保存与恢复。服务器需要保存每个客户端的传输状态,以便在客户端中断连接后能够恢复传输。 下面是一个 C# 实现的 HTTP 文件服务器断点续传示例,供参考: ```csharp using System; using System.IO; using System.Net; using System.Text; class HttpFileServer { private HttpListener _listener; private string _rootPath; public HttpFileServer(string rootPath) { _rootPath = rootPath; } public void Start() { _listener = new HttpListener(); _listener.Prefixes.Add("http://*:8080/"); _listener.Start(); Console.WriteLine("Server started on port 8080"); while (true) { var context = _listener.GetContext(); var request = context.Request; var response = context.Response; if (request.HttpMethod == "GET") { ServeFile(request, response); } else if (request.HttpMethod == "PUT") { SaveFile(request, response); } else { response.StatusCode = 405; response.Close(); } } } private void ServeFile(HttpListenerRequest request, HttpListenerResponse response) { var filePath = Path.Combine(_rootPath, request.Url.LocalPath.Substring(1)); if (File.Exists(filePath)) { var fileInfo = new FileInfo(filePath); var rangeHeader = request.Headers["Range"]; if (!string.IsNullOrEmpty(rangeHeader)) { var range = GetRange(rangeHeader, fileInfo.Length); response.StatusCode = 206; response.Headers.Add("Content-Range", $"bytes {range.Start}-{range.End}/{fileInfo.Length}"); response.ContentLength64 = range.Length; ServeRange(filePath, range, response.OutputStream); } else { response.ContentType = GetContentType(filePath); response.ContentLength64 = fileInfo.Length; ServeFile(filePath, response.OutputStream); } } else { response.StatusCode = 404; } response.Close(); } private void ServeFile(string filePath, Stream outputStream) { using (var fileStream = File.OpenRead(filePath)) { fileStream.CopyTo(outputStream); } } private void ServeRange(string filePath, Range range, Stream outputStream) { using (var fileStream = File.OpenRead(filePath)) { fileStream.Seek(range.Start, SeekOrigin.Begin); var buffer = new byte[4096]; var remaining = range.Length; while (remaining > 0) { var bytesRead = fileStream.Read(buffer, 0, (int)Math.Min(buffer.Length, remaining)); if (bytesRead == 0) { break; } outputStream.Write(buffer, 0, bytesRead); remaining -= bytesRead; } } } private void SaveFile(HttpListenerRequest request, HttpListenerResponse response) { var filePath = Path.Combine(_rootPath, request.Url.LocalPath.Substring(1)); var fileInfo = new FileInfo(filePath); if (!fileInfo.Directory.Exists) { fileInfo.Directory.Create(); } using (var fileStream = fileInfo.Open(FileMode.OpenOrCreate, FileAccess.Write)) { var rangeHeader = request.Headers["Content-Range"]; if (!string.IsNullOrEmpty(rangeHeader)) { var range = GetRange(rangeHeader, fileInfo.Length); if (range.Start != fileStream.Length) { response.StatusCode = 400; response.Close(); return; } fileStream.Seek(range.Start, SeekOrigin.Begin); } else { fileStream.SetLength(0); } request.InputStream.CopyTo(fileStream); } response.Close(); } private static string GetContentType(string filePath) { switch (Path.GetExtension(filePath)) { case ".txt": return "text/plain"; case ".html": return "text/html"; case ".js": return "application/javascript"; case ".css": return "text/css"; case ".png": return "image/png"; case ".jpg": case ".jpeg": return "image/jpeg"; case ".gif": return "image/gif"; default: return "application/octet-stream"; } } private static Range GetRange(string rangeHeader, long fileSize) { var parts = rangeHeader.Split('='); var range = parts[1].Split('-'); var start = long.Parse(range[0]); var end = range.Length > 1 ? long.Parse(range[1]) : fileSize - 1; return new Range(start, end); } private struct Range { public long Start; public long End; public Range(long start, long end) { Start = start; End = end; } public long Length => End - Start + 1; } } ``` 在此示例中,我们使用 HttpListener 类实现了一个简单的 HTTP 文件服务器,支持 GET 和 PUT 请求,可以实现文件下载和上传功能。服务器能够处理客户端请求中的 Range 头部,实现文件下载断点续传功能。同时,服务器也能够处理客户端请求中的 Content-Range 头部,实现文件上传的断点续传功能。 需要注意的是,此示例仅用于演示断点续传的基本实现原理,实际应用中还需要考虑更多的细节问题,例如文件版本控制、并发访问控制、用户认证和授权等。 ### 回答2: c是英文字母表中的第三个字母,也是拉丁字母表的一部分。它的发音类似于/k/的音,可以通过将舌头抵住硬颚,然后释放气流产生声音。c同样也是元音字母a、e、i、o、u及辅音字母前常用的一个字母。在英语中,c可以和其他字母结合形成不同的音标,例如ch、ck、cr等。在一些特定的词中,c也可以表示其他的音值,如ceiling中的/c/发音就类似/s/的音。此外,在音乐中,C也指的是C调,是一个重要的音调。在计算机科学中,C也代表着一种编程语言,由丹尼斯·里奇于1972年开发。C语言是一种高级程序设计语言,被广泛应用于软件开发、操作系统和嵌入式系统等领域。总的来说,C是一个重要的字母,在不同的领域中扮演着不同的角色。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值