在下面的极简主义示例中:
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
public class GsonStuff {
public static void main(String[] args) {
GsonBuilder builder = new GsonBuilder();
Gson gson = builder.create();
System.out.println(gson.toJson("Apostrophe: '"));
//Outputs: "Apostrophe: \u0027"
}
}
在打印输出中,撇号会被Unicode表示所取代。但是,从toJson
方法传回的String实际上包含字符''、' u'、'0'、' 0'、'2'、' 7'。
使用json对其进行解码实际上是有效的,并给出字符串“撇号:'”,与“撇号:\u0027”。我应该如何解码才能获得相同的结果?
还有一个问题,为什么一个随机的Unicode字符,比如,没有得到类似的编码?
2条答案
按热度按时间bfhwhh0e1#
默认情况下,gson Unicode会转义某些字符,
'
就是其中之一。(完整列表请参见JsonWriter中的HTML_SAFE_REPLACEMENT_CHARS
。)要禁用此功能,请执行以下操作
iq0todco2#
您可以按如下方式修改代码