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 = "";
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
我们看到序列化的结果中 若是设置为escapeHtmlChars为false,也就是不转义,那么会是什么呢?
private static GsonBuilder getGsonBuilder() {
return new GsonBuilder().disableHtmlEscaping().serializeNulls().enableComplexMapKeySerialization().serializeSpecialFloatingPointValues().setLenient();
}
测试结果为
{"name":"colorcontent","score":""}
colorcontent
我们看到序列化的结果中左右尖括号并没有被转义,反序列化也是没有进行转义。所以该escapeHtmlChars影响序列化和反序列化是否转义html字符。
什么时候要设置,什么时候不设置呢?这要看本身需求,后台和客户端打交道的时候,有时候字符串中会有=