处理JSON的Java API标准发布

作为JSON处理(JSON-P)的Java API,JSR-353已经到达了最终的批准投票阶段。JSON-P(类似于JAXP)由一个流API(类似于StAX)和一个对象模型API(类似于DOM)组成。它的参考实现是jsonp,目前正处在测试阶段,它基于CDDL v1.1 和 GPL v2 协议开放源码。JSON-P将作为即将发布的Java EE 7的一部分,同时JAX-RS会使用它作为默认的JSON实现。请注意,该API并没有包含JSON数据绑定(类似于JAXB),同时它和更流行的JSONP(JSON with padding)并没有关系。

JSON(JavaScript对象标记)是一个轻量级数据交换格式,被广泛用于Web应用程序、REST服务和NoSQL数据库。随着JSON的流行以及Java平台上诸多JSON类库(org.json、Jackson及google-gson等)的出现,现在已经到了需要对开发者创建并使用JSON的方式进行标准化的阶段。JSON-P就是即将到来的标准,它能够被独立地使用,或者作为Java EE 7容器的一部分。

JSON-P分为两个API,流API(javax.json.stream)和对象模型API(javax.json)。流API是一种底层且高效的解析和生成JSON的方式。它由两个主要的抽象构成——JsonParser和JsonGenerator。JsonParser是一个拉模式解析器,允许以向前、只读的方式访问JSON输入源。JsonGenerator则提供了向流中写入JSON的方法,并且允许使用方法链。Generator输出JSON对象中的名/值对以及JSON数组中的值。

下面是JsonParser和JsonGenerator的代码示例。首先是我们将会读取或者创建的JSON数据。

[ 
 { 
  "type" : "home", 
  "number" : "(800) 111-1111" 
 }, 
 { 
  "type" : "cell", 
  "number" : "(800) 222-2222" 
 } 
] 

下面是JsonParser示例,示例的底部是它的输出。

JsonParserFactory factory = Json.createParserFactory(null);
JsonParser parser = factory.createParser(new StringReader(json));

while (parser.hasNext()) {
  Event event = parser.next();

  switch (event) {
    case KEY_NAME: {
      System.out.print(parser.getString() + "="); break;
    }
    case VALUE_STRING: {
      System.out.println(parser.getString()); break;
    }
  }
}

type=home
number=(800) 111-1111
type=cell
number=(800) 222-2222

下面是JsonGenerator的示例,它向System.out中打印JSON。

JsonGeneratorFactory factory = Json.createGeneratorFactory(null);
JsonGenerator generator = factory.createGenerator(System.out);

generator.writeStartArray().
  writeStartObject().
    write("type", "home").
    write("number", "(800) 111-1111").writeEnd().
  writeStartObject().
    write("type", "cell").
    write("number", "(800) 222-2222").writeEnd().
  writeEnd().close();

第二部分是对象模型API,一个简单易用的高层API,它基于流API实现。它创建了一个类似于树的结构代表内存中的JSON数据,能够非常容易地进行操纵和查询。对象模型API中最主要的抽象是JsonObject和JsonArray,这两部分都是不可变的。JsonObject提供了一个Map视图,用于访问模型中未被排序的名/值对集合。JsonArray提供了一个列表视图访问排序的值序列。为了创建这些对象模型,你可以使用构建者模式(JsonObjectBuilder和JsonArrayBuilder)或者使用JsonReader从一个输入源(InputStream或者Reader)中读取它们。然后你可以使用JsonWriter将这些对象模型写入一个输出源(OutputStream或者Writer)。

下面是使用JsonArrayBuilder创建JsonArray的示例。需要再次提醒的是,我们使用的依然是上面的JSON数据。

JsonBuilderFactory factory = Json.createBuilderFactory(null);
JsonArray jsonArray = factory.createArrayBuilder()
    .add(factory.createObjectBuilder().
        add("type", "home").
        add("number", "(800) 111-1111"))
    .add(factory.createObjectBuilder().
        add("type", "cell").
        add("number", "(800) 222-2222")).build();

下面是JSONReader示例。

try (JsonReader jsonReader = Json.createReader(new StringReader(json))) {
  JsonArray array = jsonReader.readArray();
  System.out.println(array);
}

下面是JsonWriter示例。

try (JsonWriter jsonWriter = Json.createWriter(System.out)) {
  jsonWriter.writeArray(jsonArray);
}


如果你想尝试这个测试版本,那么可以下载jsonp,或者使用 javax.json:javax.json-api:1.0-b06org.glassfish:javax.json:1.0-b06 Maven 产品。你需要使用Java SE 6或者更高版本。如果想要获取更多信息,可以访问官方网站提供的JSON处理的Java API ,或者阅读JSON 处理的Javadocs 。你还可以通过YouTube观看JavaOne提供的 JSON处理的Java API呈现。

『号外』:JavaOne 2013大会将于7月22–25日在上海世博中心举行,内容涵盖使用Java SE构建现代应用程序、打造针对下一代智能设备的移动和嵌入式Java应用程序、编制基于Java EE的复杂企业解决方案以及在云环境中安全、无缝地构建和部署业务应用程序等,报名或查看详情请点击。

查看英文原文:Standard Java API for JSON

你可能感兴趣的:(处理JSON的Java API标准发布)