获取网页内容WebClient

  		/// <summary>
        /// 获取网页内容
        /// </summary>
        /// <param name="url">网址</param>
        private static string GetHtmlString(string url)
        {
            try
            {
                int timeOut = 0;
                Stopwatch sw = new Stopwatch();
                sw.Start();
                Byte[] pageData = null;
                WebClient MyWebClient;
                int timeOutCount = 0;
                while (true)
                {
                    if (sw.ElapsedMilliseconds > timeOut)
                    {
                        MyWebClient = new WebClient();
                        MyWebClient.DownloadDataCompleted += (o, e) =>
                        {
                            sw.Reset();
                            if (pageData == null)
                            {
                                pageData = e.Result;
                            }
                        };
                        MyWebClient.DownloadDataAsync(new Uri(url));
                        sw.Restart();
                        timeOut = 5000;
                        timeOutCount ++;
                    }
                    Thread.Sleep(1000);
                    if (pageData != null)
                    {
                        break;
                    }
                    if (timeOutCount == 3)
                    {
                        sw.Stop();
                        return null;
                    }
                }
                sw.Stop();
                string pageHtml = Encoding.UTF8.GetString(pageData); //如果获取网站页面采用的是UTF-8
                return pageHtml;
            }
            catch (Exception e)
            {
                Console.WriteLine(e.Message);
                return null;
            }
        }

猜你喜欢

转载自blog.csdn.net/zoysia1314/article/details/86064704
今日推荐