|
using System;
using System.NET;
using System.Text;
using System.Text.RegularExpressions;
class Program
{
// 獲取網(wǎng)頁(yè)的HTML內(nèi)容,根據(jù)網(wǎng)頁(yè)的charset自動(dòng)判斷Encoding
static string GetHtml(string url)
{
return GetHtml(url, null);
}
// 獲取網(wǎng)頁(yè)的HTML內(nèi)容,指定Encoding
static string GetHtml(string url, Encoding encoding)
{
byte[] buf = new WebClient().DownloadData(url);
if (encoding != null) return encoding.GetString(buf);
string html = Encoding.UTF8.GetString(buf);
encoding = GetEncoding(html);
if (encoding == null || encoding == Encoding.UTF8) return html;
return encoding.GetString(buf);
}
// 根據(jù)網(wǎng)頁(yè)的HTML內(nèi)容提取網(wǎng)頁(yè)的Encoding
static Encoding GetEncoding(string html)
{
string pattern = @"(?i)/bcharset=(?<charset>[-a-zA-Z_0-9]+)";
string charset = Regex.Match(html, pattern).Groups["charset"].Value;
try { return Encoding.GetEncoding(charset); }
catch (ArgumentException) { return null; }
}
// 程序入口
static void Main()
{
Console.WriteLine(GetHtml(http://www.jb51.NET));
Console.Read();
}
}
AspNet技術(shù):asp.net 網(wǎng)頁(yè)編碼自動(dòng)識(shí)別代碼,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。