有人能澄清一下Gson的Unicode编码吗?

ddrv8njm  于 2022-11-06  发布在  其他
关注(0)|答案(2)|浏览(178)

在下面的极简主义示例中:

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字符,比如,没有得到类似的编码?

bfhwhh0e

bfhwhh0e1#

默认情况下,gson Unicode会转义某些字符,'就是其中之一。(完整列表请参见JsonWriter中的HTML_SAFE_REPLACEMENT_CHARS。)
要禁用此功能,请执行以下操作

builder.disableHtmlEscaping();
iq0todco

iq0todco2#

您可以按如下方式修改代码

import com.google.gson.Gson;
import com.google.gson.GsonBuilder;

public class GsonStuff {

    public static void main(String[] args) {
        GsonBuilder builder = new GsonBuilder().disableHtmlEscaping();
        Gson gson = builder.create();
        System.out.println(gson.toJson("Apostrophe: '"));
        //Outputs: "Apostrophe: \u0027"
    }   
}

相关问题