asp.net 网页编码自动识别代码
更新时间:2008年09月10日 01:03:15 作者:
另外一位网友空间/IV提供的代码,功能同HttpWebRequest获取网页源代码时自动识别网页编码
复制代码 代码如下:
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(https://www.jb51.net));
Console.Read();
}
}
相关文章
比较简单的将数据信息导入wrod文档方案(C# for word)
史上最简单将数据信息导入wrod文档方案(C# for word)2010-01-01
asp.net Javascript获取CheckBoxList的value
最近在做一个BS的小项目,记得自己搞asp.net的时候,还是两年以前,大部分的东西只是有点印象,忘得差不多了,所以这次也算是温习的过程吧,一边学习,一边赶工,呵呵呵。。。。2009-12-12
ASP.NET WebForms实现全局异常捕获与处理的最佳实践
文章介绍了在ASP.NET WebForms中实现全局异常捕获与处理的最佳实践,包括在Global.asax中使用Application_Error、在Web.config中配置customErrors、在代码中使用try-catch、全局异常过滤以及使用日志记录库等方法,感兴趣的朋友一起看看吧2025-01-01


最新评论