使用C# Winform應(yīng)用程序獲取網(wǎng)頁源文件的解決方法
在C# Winform 應(yīng)用程序中,獲取某網(wǎng)頁的源文件,可以用以下方法:
首先引入名稱空間
using System.IO;
using System.Net;
WebClient MyWebClient = new WebClient(); MyWebClient.Credentials = CredentialCache.DefaultCredentials;//獲取或設(shè)置用于向Internet資源的請求進(jìn)行身份驗(yàn)證的網(wǎng)絡(luò)憑據(jù) Byte[] pageData = MyWebClient.DownloadData("http://www.baidu.com"); //string pageHtml = Encoding.Default.GetString(pageData); FileStream file = new FileStream("C:\\test.html", FileMode.Create); file.Write(pageData, 0, pageData.Length);
附,c# 獲取網(wǎng)頁源碼的代碼舉例。
C# 獲取指定網(wǎng)頁HTML原代碼可使用:WebClient WebRequest HttpWebRequest 三種方式。
當(dāng)然也可使用webBrowse,有興趣的朋友,可以自己研究下。
1,WebClient方式
private string GetWebClient(string url) { string strHTML = ""; WebClient myWebClient = new WebClient(); Stream myStream = myWebClient.OpenRead(url); StreamReader sr = new StreamReader(myStream, System.Text.Encoding.GetEncoding("utf-8")); strHTML = sr.ReadToEnd(); myStream.Close(); return strHTML; }
2,WebRequest方式
private string GetWebRequest(string url) { Uri uri = new Uri(url); WebRequest myReq = WebRequest.Create(uri); WebResponse result = myReq.GetResponse(); Stream receviceStream = result.GetResponseStream(); StreamReader readerOfStream = new StreamReader(receviceStream, System.Text.Encoding.GetEncoding("utf-8")); string strHTML = readerOfStream.ReadToEnd(); readerOfStream.Close(); receviceStream.Close(); result.Close(); return strHTML; }
3,HttpWebRequest方式
private string GetHttpWebRequest(string url) { Uri uri = new Uri(url); HttpWebRequest myReq = (HttpWebRequest)WebRequest.Create(uri); myReq.UserAgent = "User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; .NET CLR 1.0.3705"; myReq.Accept = "*/*"; myReq.KeepAlive = true; myReq.Headers.Add("Accept-Language", "zh-cn,en-us;q=0.5"); HttpWebResponse result = (HttpWebResponse)myReq.GetResponse(); Stream receviceStream = result.GetResponseStream(); StreamReader readerOfStream = new StreamReader(receviceStream, System.Text.Encoding.GetEncoding("utf-8")); string strHTML = readerOfStream.ReadToEnd(); readerOfStream.Close(); receviceStream.Close(); result.Close(); return strHTML; }
注意:“utf-8”應(yīng)與指定網(wǎng)頁的編碼對應(yīng)。
總結(jié)
HttpWebRequest 方式最復(fù)雜,但確提供了更多的選擇性。
有的網(wǎng)站檢測客戶端的UserAgent!如163.com,如果使用WebClient WebRequest方式獲取,將獲取到的是錯(cuò)誤提示頁面的內(nèi)容。
HttpWebRequest沒有這個(gè)問題。
測試環(huán)境:WIN2003 + VS2005 + C# + winForm
- C#基于正則表達(dá)式實(shí)現(xiàn)獲取網(wǎng)頁中所有信息的網(wǎng)頁抓取類實(shí)例
- 使用C#正則表達(dá)式獲取必應(yīng)每日圖片地址
- C#正則表達(dá)式獲取下拉菜單(select)的相關(guān)屬性值
- C#使用正則表達(dá)式抓取網(wǎng)站信息示例
- C#通過正則表達(dá)式實(shí)現(xiàn)提取網(wǎng)頁中的圖片
- c# 正則表達(dá)式對網(wǎng)頁進(jìn)行有效內(nèi)容抽取
- 常用正則 常用的C#正則表達(dá)式
- C#的正則表達(dá)式Regex類使用簡明教程
- C# 正則表達(dá)式經(jīng)典分類整理集合手冊
- C#中的正則表達(dá)式 學(xué)習(xí)資料
- WinForm使用正則表達(dá)式提取內(nèi)容的方法示例
相關(guān)文章
C#操作本地文件及保存文件到數(shù)據(jù)庫的基本方法總結(jié)
C#使用System.IO中的文件操作方法在Windows系統(tǒng)中處理本地文件相當(dāng)順手,這里我們還總結(jié)了在Oracle中保存文件的方法,嗯,接下來就來看看整理的C#操作本地文件及保存文件到數(shù)據(jù)庫的基本方法總結(jié)2016-05-05C#實(shí)現(xiàn)的算24點(diǎn)游戲算法實(shí)例分析
這篇文章主要介紹了C#實(shí)現(xiàn)的算24點(diǎn)游戲算法,實(shí)例分析了算24點(diǎn)游戲相關(guān)的運(yùn)算技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04C#實(shí)現(xiàn)DevExpress本地化實(shí)例詳解
這篇文章主要介紹了C#實(shí)現(xiàn)DevExpress本地化,以實(shí)例形式較為詳細(xì)的分析了DevExpress本地化的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08C#使用this關(guān)鍵字實(shí)現(xiàn)串聯(lián)構(gòu)造函數(shù)調(diào)用方法
這篇文章主要介紹了C#使用this關(guān)鍵字實(shí)現(xiàn)串聯(lián)構(gòu)造函數(shù)調(diào)用方法,實(shí)例分析了使用this關(guān)鍵字串聯(lián)構(gòu)造函數(shù)的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01C#中使用Cache框架快速實(shí)現(xiàn)Cache操作
這篇文章介紹了C#中使用Cache框架快速實(shí)現(xiàn)Cache操作的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06