用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > Net教程

asp.net 网页编码自动识别代码

时间:2015-01-29  来源:互联网  作者:佚名
复制代码 代码如下:
using System;
using System.Net;
using System.Text;
using System.Text.RegularExpressions;

class Program
{
// 获取网页的HTML内容,根据网页的charset自动判断Encoding
static string GetHtml(string url)
{
return GetHtml(url, null);
}

// 获取网页的HTML内容,指定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);
}

// 根据网页的HTML内容提取网页的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();
}
}
来顶一下
返回首页
返回首页
推荐资讯
Asp.net 通用万级数据分页代码[修正下载地址] Asp.net 通用万级数据分页代码[修正1.主题,Asp.net环境下,通用的数据分页(包括Oracle,SqlServer
asp.net 2.0多语言网站解决方法 asp.net 2.0多语言网站解决方法首先在App_GlobalResources新建resx资源文件。如: 不同语言
相关文章
栏目更新
栏目热门