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


复制代码 代码如下:

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.phpstudy.net));

Console.Read();
}
}



相关阅读:
30个JavaScript滑动和滚动效果
如何用php作linux自动执行脚本?
《PHP编程最快明白》第四讲:日期、表单接收、session、cookie
网页设计中典型的header代码结构
CSS实例教程:CSS Hack
mysql SELECT语句去除某个字段的重复信息
在ASP中调用存储过程的几种方法
php中global和$GLOBALS[]的分析之一
教你只用一个Validator对多个控件进行验证
使用Windows7用户不可错过的77条小知识
拖动布局之保存布局页面cookies篇
ajax 技术和原理分析
Discuz数据库结构参考 方便二次开发
Windows7使用Aero样式怀念经典开始菜单
快速导航

Copyright © 2016 phpStudy |