中文与韩、日文混排出现在Gb2312编码的Aspx的处理方法
来源:岁月联盟
时间:2008-09-21
经过研究,发现这个问题可以通过Html实体的方法解决。
对于Html实体请参考:
测试代码:
Byte[] bComments = Encoding.UTF8.GetBytes("一ンブル????中文");
char[] cComments = Encoding.UTF8.GetChars(bComments);
StringBuilder charBuilder = new StringBuilder();
foreach(char c in cComments)
{
if(c > ’/u0800’)
{
charBuilder.Append("&#");
charBuilder.Append((int)c);
}
else
{
charBuilder.Append(c);
}
}
Response.Write(charBuilder.ToString());
这段代码的作用是将所有的中文、韩文、日文字符通过硬编码输出成为html实体。而Html实体是不受ResponseEncoding和页面编码集影响的。
说明:
/u0800 以上的为中、韩、日字符。
中文的范围:/u4e00 - /u9fa5,日文在/u0800 - /u4e00,韩文为/u9fa5以上。
这个方法仅仅是为了解决小范围问题,如果各位有更好的办法请指教。
上一篇:GB2312简体中文编码表
下一篇:网页设计教程之论摹仿和抄袭