宽字符编码和解码通用类[CodeWidthChartUtility]

  在做jsonp传递的时候遇到一个问题,当有特殊字符或中文的时候就会导致数据错误或者是乱码,刚开始有js的编码和解码和正则,都比较麻烦,现在找到了一种合适的解决方案,宽字符编码,js端会自动解析,能处理以上问题,以下是自己封装的通用类。

using System;
using System.Text;

/// <summary>
/// author:Stone_W
/// date:2010.12.23
/// desc:宽字符编码和解码
/// </summary>
public class CodeWidthChartUtility
{
    public CodeWidthChartUtility() { }

    // 无需转码的字符
    private static string NonEncodingChats = "abcdefghijklmnopqrstuvwxyz0123456789`!@#$%^&*()_+|-=\\,./;'[]{}:<>?";

    #region 判断需要转换的字符
    /// <summary>
    /// 判断需要转换的字符
    /// </summary>
    /// <param name="charValue">判断字符</param>
    /// <returns>bool</returns>
    private static bool IsToWindthChart(char charValue)
    {
        NonEncodingChats = NonEncodingChats.ToUpper() + NonEncodingChats.ToLower();
        return NonEncodingChats.IndexOf(charValue) == -1;
    }
    #endregion

    #region 宽字符编码
    /// <summary>
    /// 宽字符编码
    /// 1.编码后 有js控制 浏览器会自动解析[js无需解码]
    /// 2.后台控制xxx.InnerHtml=宽字符 会原样输出宽字符串[后台控制需要手动解析]
    /// </summary>
    /// <param name="StrValue">需要编码的字符串</param>
    /// <returns>编码后的宽字符串</returns>
    public static string WidthChartEncoding(string StrValue)
    {
        StringBuilder sb = new StringBuilder();
        foreach (char item in StrValue)
        {
            if (IsToWindthChart(item))  // 判断需要转换的字符
            {
                sb.Append(String.Format("\\u{0:x4}", (int)item));
            }
            else
            {
                sb.Append(item);
            }
        }
        return sb.ToString();
    }
    #endregion

    #region 宽字符解码
    /// <summary>
    /// 宽字符解码
    /// 1.后台才需要手动解码
    /// 2.js 控制的浏览器会自动解码宽字符
    /// </summary>
    /// <param name="WidthStr">宽字符串</param>
    /// <returns>一般能看懂的字符</returns>
    public static string WidthChartDecoding(string WidthStr)
    {
        StringBuilder sb = new StringBuilder();
        string[] _ValueList = WidthStr.Split(new char[] { '\\', 'u' }, StringSplitOptions.RemoveEmptyEntries);
        for (int i = 0; i != _ValueList.Length; i++)
        {
            char _ValueChar = Convert.ToChar(Convert.ToUInt16(_ValueList[i], 16));
            sb.Append(_ValueChar.ToString());
        }
        return sb.ToString();
    }
    #endregion

}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏微信公众号:Java团长

HashMap和Hashtable的区别

HashMap和Hashtable的比较是Java面试中的常见问题,用来考验程序员是否能够正确使用集合类以及是否可以随机应变使用多种思路解决问题。HashMap...

13110
来自专栏技术博客

编写高质量代码改善C#程序的157个建议[为泛型指定初始值、使用委托声明、使用Lambda替代方法和匿名方法]

  泛型并不是C#语言一开始就带有的特性,而是在FCL2.0之后实现的新功能。基于泛型,我们得以将类型参数化,以便更大范围地进行代码复用。同时,它减少了泛型类及...

9450
来自专栏恰童鞋骚年

.NET基础拾遗(3)字符串、集合和流

  众所周知,在.NET中String是引用类型,具有不可变性,当一个String对象被修改、插入、连接、截断时,新的String对象就将被分配,这会直接影响到...

10710
来自专栏jessetalks

背后的故事之 - 快乐的Lambda表达式(二)

快乐的Lambda表达式   上一篇 背后的故事之 - 快乐的Lambda表达式(一)我们由浅入深的分析了一下Lambda表达式。知道了它和委托以及普通方法的区...

28240
来自专栏分布式系统和大数据处理

基于业务对象(列表)的排序

在上一篇文章 基于业务对象的筛选 中,我们讨论了如何实现Predicate<T>(T object)委托,自定义DateFilter 类来对业务对象进行筛选。与...

11220
来自专栏大内老A

WCF技术剖析之十三:序列化过程中的已知类型(Known Type)

DataContractSerializer承载着所有数据契约对象的序列化和反序列化操作。在上面一篇文章(《数据契约(Data Contract)和数据契约序列...

288100
来自专栏恰童鞋骚年

.NET基础拾遗(2)面向对象的实现和异常的处理基础

  在C#中申明一个类型时,只支持单继承(即继承一个父类),但支持实现多个接口(Java也是如此)。像C++可能会支持同时继承自多个父类,但.NET的设计小组认...

8610
来自专栏大内老A

WCF技术剖析之十四:泛型数据契约和集合数据契约(下篇)

在.NET中,所有的集合都实现了IEnumerable接口,比如Array、Hashtable、ArrayList、Stack、Queue等。有的集合要求元素具...

28160
来自专栏林德熙的博客

win10 uwp 反射

本文在h神的指导下完成。 反射是强大的好用的,我们可以添加新功能不修改之前的代码,通过使用反射得到。 本文下面和大家说如何做一个和WPF一样的反射功能,如何才能...

12120
来自专栏xiaoxi666的专栏

【模板小程序】非负数2~62任意进制转换(普通版本+大数版本)

再来一个针对大数的版本,而且直接在源进制和目标进制之间转换(不需要先转换为10进制),可以说是十分厉害。参考了http://blog.csdn.net/jast...

7620

扫码关注云+社区

领取腾讯云代金券