123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- using System;
- using System.IO;
- using System.Net;
- using System.Threading;
- using System.Windows.Threading;
-
- namespace XHWK.WKTool.Helpers
- {
- internal class ZJDownloadUtil
- {
- public static void downloadFile(string url, string savepath)
- {
- string path = savepath;
- string filename = url.Substring(url.LastIndexOf("/") + 1);
- if (!url.StartsWith("http") || filename == null || filename == "")
- {
- return;
- }
- path += filename;
-
- HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
-
- HttpWebResponse response = request.GetResponse() as HttpWebResponse;
-
- Stream responseStream = response.GetResponseStream();
-
-
- Stream stream = new FileStream(path, FileMode.Create);
-
- byte[] bArr = new byte[1024];
- int size = responseStream.Read(bArr, 0, bArr.Length);
- while (size > 0)
- {
- stream.Write(bArr, 0, size);
- size = responseStream.Read(bArr, 0, bArr.Length);
- }
- stream.Close();
- responseStream.Close();
- }
-
-
-
-
- public static Thread downloadFileWithCallback(
- string url,
- int position,
- string savepath,
- Dispatcher dispatcher,
- ZJDownloadCallback callback
- )
- {
-
- string path = savepath;
- string filename = url.Substring(url.LastIndexOf("/") + 1);
- path += filename;
- if (!url.StartsWith("http") || filename == null || filename == "")
- {
- return null;
- }
- Thread thread = new Thread(o =>
- {
- FileInfo fi = new FileInfo(path);
- if (fi.Exists)
- {
- dispatcher.Invoke(new Action(() =>
- {
- callback.downloadEnd(position, path);
- }));
- }
- else
- {
- string temppath = path + ".tmp";
- if (File.Exists(temppath))
- {
-
- temppath += "1";
- while (File.Exists(temppath))
- {
- temppath += "1";
- if (!File.Exists(temppath))
- {
- break;
- }
- }
-
- }
-
- dispatcher.Invoke(new Action(() =>
- {
- callback.downloadBegin(position);
- }));
-
- try
- {
- HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
- HttpWebResponse response = request.GetResponse() as HttpWebResponse;
- Stream responseStream = response.GetResponseStream();
-
-
- Stream stream = new FileStream(temppath, FileMode.Create);
- long totalSize = response.ContentLength;
- byte[] bArr = new byte[1024];
- int size = responseStream.Read(bArr, 0, bArr.Length);
- long readsize = 0;
- while (size > 0)
- {
- readsize += size;
- stream.Write(bArr, 0, size);
- size = responseStream.Read(bArr, 0, bArr.Length);
-
- dispatcher.Invoke(new Action(() =>
- {
- callback.downloadProgress(position, (int)(readsize * 100 / totalSize));
- }));
- }
- stream.Close();
- responseStream.Close();
- FileInfo fitemp = new FileInfo(temppath);
- fitemp.MoveTo(path);
- dispatcher.Invoke(new Action(() =>
- {
- callback.downloadEnd(position, path);
- }));
- }
- catch (Exception ex)
- {
- dispatcher.Invoke(new Action(() =>
- {
- callback.downloadError(position, ex.Message);
- }));
-
- }
-
- }
- });
- thread.Start();
- return thread;
- }
-
-
-
-
- public static void downloadFileWithCallback(
- string url,
- int position,
- Dispatcher dispatcher,
- ZJDownloadCallback callback
- )
- {
- string path = AppDomain.CurrentDomain.BaseDirectory + "temp\\";
- downloadFileWithCallback(url, position, path, dispatcher, callback);
- }
-
- public interface ZJDownloadCallback
- {
-
-
-
-
- void downloadBegin(int position);
-
-
-
-
-
-
- void downloadProgress(int position, int progress);
-
-
-
-
-
-
- void downloadEnd(int position, string filepath);
-
-
-
-
-
- void downloadError(int position, string msg);
-
- }
- }
- }
|