1

我在服务器上运行 REST 服务,我想将我的 POJO 列表转换为 Json。我不想使用@XMLRootElement JA-RX,因为它只适用于 XML。如果你谷歌你会发现 Jackson 是 Json 非常好的选择。

有没有人解决了这个问题,请粘贴完整的服务器和客户端代码?

注意:我花了 16 个小时才知道如何做到这一点,当我回答问题时,他们删除了我的答案,所以我决定把它放在这里以节省其他人宝贵的时间,我相信知识共享。如果你能改进我的代码。我总是乐于接受建议。

4

2 回答 2

12

详细回复包括带有JSON Marshalling 和 Unmarshalling的服务器客户端示例实现

注意: Json POJO 映射功能是使用 Jackson 完成的

我花了一整天的时间来查找为什么找不到消息正文写入。我做错的是我JAXB javax.xml.bind.annotation @XMLRootElement在我的 Jersey 1.17.1 Web 服务中使用,我试图用 Jackson 解组它。

Acutally 如果你谷歌它,你会发现JAXB它只对 XML 有好处,但对 JSON Jackson 来说非常好。我还忘记在我web.xml的启用 POJO 映射功能的配置参数中添加一些配置参数。

这是您的 servlet 映射应该如何启用 Jackson 的 POJO 映射功能的快照。

<!-- WebService -->
  <servlet>
        <servlet-name>REST Service</servlet-name>
        <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>com.sun.jersey.spi.container.ContainerRequestFilters</param-name>
            <param-value>com.sun.jersey.api.container.filter.LoggingFilter;com.algo.server.webservice.WebServiceRequestFilter</param-value>
        </init-param>
        <init-param>
            <param-name>com.sun.jersey.config.property.packages</param-name>
            <param-value>com.algo.server.webservice;org.codehaus.jackson.jaxrs</param-value>
        </init-param>
         <init-param>
        <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
        <param-value>true</param-value>
    </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>REST Service</servlet-name>
        <url-pattern>/rest/*</url-pattern>
    </servlet-mapping>

您还需要将这些 jar 文件添加到您的 WEB-INF/libs 文件夹中

  • 杰克逊核心asl-1.9.2.jar
  • jackson-mapper-asl-1.9.2.jar
  • 杰克逊-xc-1.9.2.jar
  • 杰克逊-jaxrs-1.9.2.jar

这是一个返回一些对象列表的示例 Web 服务方法

    @GET
@Produces({ MediaType.APPLICATION_JSON })
@Path("/clientId/{client_id}/clientDept/{client_department}/clientLoc/{client_location}")
public Response getTasksForClientId(@PathParam("client_id") String pClientId,
        @PathParam("client_department") String pClientDepartment,
        @PathParam("client_location") String pClientLocation) {
    List<Task> list = new ArrayList<Task>(10);
    Task task = null;
    for (int i = 0; i < 10; i++) {
        task = new Task();
        task.setComments("These are test comments");
        task.setCreatedBy(11L);
        task.setCreatedOn(new Date());
        task.setFromDay(new Date());
        task.setFromTime(new Date());
        task.setToTime(new Date());
        task.setToDay(new Date());
        task.setUpdatedOn(new Date());
        task.setLocation("Pakistan Punajb");
        task.setSpecialCoverImage("webserver\\cover\\cover001.png");
        task.setTargetId(1L);
        task.setTargetPlaceHolder(2);
        task.setUpdatedBy(23234L);
        list.add(task);
    }
    GenericEntity<List<Task>> entity = new GenericEntity<List<Task>>(list) {
    };
    return Response.ok(entity).build();
}

客户端

现在如何使用在客户端将此 JSON 对象转换为相同的List<T>对象。这是一个sinch :-)

您需要从您转换为 POJO 的服务器中放入相同的类。应该是一样的

private void checkForUpdate() {
        ClientConfig clientConfig = new DefaultClientConfig();
        clientConfig.getFeatures().put(JSONConfiguration.FEATURE_POJO_MAPPING, Boolean.TRUE);
        clientConfig.getClasses().add(JacksonJsonProvider.class);
        Client client = Client.create(clientConfig);                

        WebResource webResource = client.resource("http://localhost:8080/some-server");

        WebResource wr = webResource.path("rest").path("taskPublisherService").path("clientId/12").path("clientDept/2").path("clientLoc/USA");

        ClientResponse clientResponse = wr.type(MediaType.APPLICATION_JSON).get(ClientResponse.class);

        List<Task> lists = clientResponse.getEntity(new GenericType<List<Task>>() {});

        System.out.println(lists);   

    }
于 2013-09-06T06:44:56.757 回答
3

来自 Jersey 的这个包含所有上述 JAR:

<dependency>
    <groupId>com.sun.jersey</groupId>
    <artifactId>jersey-json</artifactId>
    <version>${version.jersey}</version>
    <scope>runtime</scope>
</dependency>
于 2013-10-30T19:06:17.577 回答