看到网上不少地方传输中文的时候用的是类似/u4e2d/u56fd的字符,就是Unicode编码的字符,想知道具体什么内容,又不容易看出来,所以想把这个字符集解码为正常的字符。
开始我通过Encoding转换编码格式,发现行不通,怎么都不能正常解开,然后在网上淘了些类似的解码方案,有可行的,不过我发现写的有点麻烦,而且如果我成批的Unicode字符就无法直接输出了,然后我看呀看呀看,终于,我发现了char类的两个方法:一个是char.ConvertFromUtf32,注释说:将指定的Unicode码位转换为UTF-16编码字符串,这不就是解码的吗;还有一个是char.ConvertToUtf32,注释说:该方法是将字符串中指定位置的UTF-16编码字符转换为Unicode码位,哈,其实就是把普通的字符转换为Unicode字符集。
好了,有了这两个方法就可以编码或解码了,现在打开VS新建Winform应用程序(C#语言),窗体界面如下:
上面的文本框中输入的是Unicode字符集,下面输入的是正常的字符串,最后可以批量相互转换。
最终效果如图:
关键代码如下:
好了,问题终于解决了,旨在给有相同困惑的朋友带来帮助。、
以上的代码有些部分是为了周全所有的转换,所以有些不太容易看清~
本例在VS2005 及.Net Formwork2.0中运行通过。
需要Demo的给我留言哦。。