public
static
string
GetEncodingString(
string
srcString)
{
Encoding e8859Encode = Encoding.GetEncoding("iso-8859-1");
Encoding srcEncode = Encoding.GetEncoding("gb2312");
Encoding dstEncode = Encoding.Unicode;
byte[] srcBytes = e8859Encode.GetBytes(srcString);//用iso-8859-1去转换源字符串
byte[] dstBytes = Encoding.Convert(srcEncode, dstEncode, srcBytes);//但是,是从gb2312转到unicode的
char[] dstChars = new char[dstEncode.GetCharCount(dstBytes, 0, dstBytes.Length)];
dstEncode.GetChars(dstBytes, 0, dstBytes.Length, dstChars, 0);
return new string(dstChars);
}
具体原因我推测是因为数据过来是ISO-8859-1,但.Net底层处理成了Gb2312了,所以需要通过两种编码转换成Unicode才能正常显示,听说在Java中只要new String(s.getBytes("ISO-8859-1"),"gb2312");就OK了。
http://www.51zxw.net/study.asp?vip=8963801
没事同志们可以来光顾下,绝对有好处

本文详细解释了在.NET环境中将不同编码的字符串进行转换的方法,包括使用特定编码获取字符串字节,通过编码转换实现从ISO-8859-1到GB2312再到Unicode的转换过程,并讨论了与Java中类似操作的区别。

5111

被折叠的 条评论
为什么被折叠?



