Gson-特殊字符的转义-disableHtmlEscaping()

escapeHtmlChars属性
GsonBuilder相关方法

  public GsonBuilder disableHtmlEscaping() {
    this.escapeHtmlChars = false;
    return this;
  }

该属性默认为true,表示会将html中的字符例如< >这样的字符处理转义掉。设置为false后,就不会转义这些字符。直接看下面的例子更直观一些
首先创建默认escapeHtmlChars为true的GsonBuilder

private static GsonBuilder getGsonBuilder() {
        return new GsonBuilder().serializeNulls().enableComplexMapKeySerialization().serializeSpecialFloatingPointValues().setLenient();
    }

测试代码:

 String content = "<font color=\"#FB4E44\">";
        test te= new test("colorcontent",content);
        //序列化
        String result = getGson().toJson(te);
        System.out.println(result);
        te = getGson().fromJson(result,te.getClass());
        //反序列化结果
        System.out.println(te.name+" "+te.score);

序列化结果和反序列化结果分别为:

{"name":"colorcontent","score":"\u003cfont color\u003d\"#FB4E44\"\u003e"}
colorcontent <font color="#FB4E44">

我们看到序列化的结果中<转义成了\u003c,反序列化后又将u003c转义为<了。
若是设置为escapeHtmlChars为false,也就是不转义,那么会是什么呢?

 private static GsonBuilder getGsonBuilder() {
        return new GsonBuilder().disableHtmlEscaping().serializeNulls().enableComplexMapKeySerialization().serializeSpecialFloatingPointValues().setLenient();
    }

测试结果为

{"name":"colorcontent","score":"<font color=\"#FB4E44\">"}
colorcontent <font color="#FB4E44">

我们看到序列化的结果中左右尖括号并没有被转义,反序列化也是没有进行转义。所以该escapeHtmlChars影响序列化和反序列化是否转义html字符。
什么时候要设置,什么时候不设置呢?这要看本身需求,后台和客户端打交道的时候,有时候字符串中会有= <等特殊符号,一般我们都是需要转义???

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值