使用C#獲取網(wǎng)頁HTML源碼的例子
最近在做一個項目,其中一個功能是根據(jù)一個URL地址,獲取到網(wǎng)頁的源代碼。在ASP.NET(C#)中,獲取網(wǎng)頁源代碼貌似有很多種方法,我隨便搞了一個簡單的WebClient,非常簡單容易。但后面一個非常惱火的問題出來了,那就是中文的亂碼。
通過仔細研究,中文的網(wǎng)頁不外乎GB2312和UTF-8這兩種編碼。于是有了下面這段代碼:
/// <summary>
/// 根據(jù)網(wǎng)址的URL,獲取源代碼HTML
/// </summary>
/// <param name="url"></param>
/// <returns></returns>
public static string GetHtmlByUrl(string url)
{
using (WebClient wc = new WebClient())
{
try
{
wc.UseDefaultCredentials = true;
wc.Proxy = new WebProxy();
wc.Proxy.Credentials = CredentialCache.DefaultCredentials;
wc.Credentials = System.Net.CredentialCache.DefaultCredentials;
byte[] bt = wc.DownloadData(url);
string txt = System.Text.Encoding.GetEncoding("GB2312").GetString(bt);
switch (GetCharset(txt).ToUpper())
{
case "UTF-8":
txt = System.Text.Encoding.UTF8.GetString(bt);
break;
case "UNICODE":
txt = System.Text.Encoding.Unicode.GetString(bt);
break;
default:
break;
}
return txt;
}
catch (Exception ex)
{
return null;
}
}
}
稍微解釋一下,這里使用了WebClient創(chuàng)建了一個wc對象(這命名有點尷尬了)。然后調(diào)用wc對象的DownloadData方法,傳入URL值,返回一個字節(jié)數(shù)組。默認使用GB2312來讀取這個字節(jié)數(shù)組,把它轉(zhuǎn)換成字符串。從網(wǎng)頁源代碼的字符串中查找網(wǎng)頁的編碼格式的特征字符,如找到charset="utf-8"這樣的信息,來判斷當前網(wǎng)頁的編碼格式。
GetCharset這個函數(shù)就是來獲取當前網(wǎng)頁的編碼格式的,具體代碼如下:
/// 從HTML中獲取獲取charset
/// </summary>
/// <param name="html"></param>
/// <returns></returns>
public static string GetCharset(string html)
{
string charset = "";
Regex regCharset = new Regex(@"content=[""'].*\s*charset\b\s*=\s*""?(?<charset>[^""']*)", RegexOptions.IgnoreCase);
if (regCharset.IsMatch(html))
{
charset = regCharset.Match(html).Groups["charset"].Value;
}
if (charset.Equals(""))
{
regCharset = new Regex(@"<\s*meta\s*charset\s*=\s*[""']?(?<charset>[^""']*)", RegexOptions.IgnoreCase);
if (regCharset.IsMatch(html))
{
charset = regCharset.Match(html).Groups["charset"].Value;
}
}
return charset;
}
感覺寫得不是很好,先將就著用,呵呵。小編原創(chuàng),轉(zhuǎn)載注明,呵呵。
相關(guān)文章
C#使用ICSharpCode.SharpZipLib.dll進行文件的壓縮與解壓功能
這篇文章主要介紹了C#使用ICSharpCode.SharpZipLib.dll進行文件的壓縮與解壓功能,需要的朋友可以參考下2017-12-12C#實現(xiàn)將商品金額小寫轉(zhuǎn)換成大寫的方法
這篇文章主要介紹了C#實現(xiàn)將商品金額小寫轉(zhuǎn)換成大寫的方法,涉及C#數(shù)組與字符串的相關(guān)操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-08-08DevExpress的DateEdit設(shè)置顯示日期和時間的方法
本文主要介紹了DevExpress的DateEdit設(shè)置顯示日期和時間的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08C#實現(xiàn)PDF簽名時添加時間戳的2種方法(附VB.NET代碼)
在PDF添加簽名時,支持添加可信時間戳來保證文檔的法律效應。本文,將通過C#程序代碼介紹如何添加可信時間戳,可通過2種方法來實現(xiàn)。感興趣的可以了解一下2021-05-05