c# Unicode字符串的解码
发布日期:2021-05-09 04:01:25 浏览次数:15 分类:博客文章

本文共 773 字,大约阅读时间需要 2 分钟。

前两天工作中遇到个奇怪的问题,一个unicode字符串(即“\uXXXX”形式)变量,调用HttpUtility.UrlDecode解码过后,还是原样,要么就是乱码状态。无奈之下只能自己写一个解码函数。

实现过程如下:

private string DecodeUnicode(string s)        {            Regex reUnicode = new Regex(@"\\u([0-9a-fA-F]{4})", RegexOptions.Compiled);            return reUnicode.Replace(s, m =>            {                short c;                if (short.TryParse(m.Groups[1].Value, System.Globalization.NumberStyles.HexNumber, CultureInfo.InvariantCulture, out c))                {                    return "" + (char)c;                }                return m.Value;            });        }

 后续问题:

如上所述,调用自己写的这么一个解码函数后,确实解决了unicode变量解码的问题。但是网站发布后,线上一直报错,导致整个网站都崩溃无法运行,但是我本地一点问题没有。

后来查找了半天,终于明白了问题所在。

因为该方法用到了Linq, 所以一定要注意在定义该方法的类文件中加入命名空间的引用,否则发布后就可能出现问题。

using System.Linq;

 

上一篇:Jquery清除:hover事件
下一篇:GridView的RowDataBound事件中获取当前行内容的几种方法

发表评论

最新留言

做的很好,不错不错
[***.243.131.199]2025年04月19日 00时25分17秒