我有一个工作的json服务,如下所示:
@POST
@Path("/{id}/query")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(JSON)
public ListWrapper query(@Context SecurityContext sc, @PathParam("id") Integer projectId, Query searchQuery) {
...
return result
}
查询对象看起来像这样,当发布该Query对象的json表示时,它很好用。
@XmlRootElement
public class Query {
Integer id;
String query;
... // Getters and Setters etc..
}
现在我想从客户端填充该对象,并使用Jersey客户端将该Query对象发布到服务并获取JSONObject作为结果。我的理解是,可以先将它转换为json对象,然后将其作为String发布。
我尝试过类似的东西,但我觉得我错过了一些东西。
public static JSONObject query(Query searchQuery){
String url = baseUrl + "project/"+searchQuery.getProjectId() +"/query";
WebResource webResource = client.resource(url);
webResource.entity(searchQuery, MediaType.APPLICATION_JSON_TYPE);
JSONObject response = webResource.post(JSONObject.class);
return response;
}
我正在使用Jersey 1.12。
非常感谢任何正确方向的帮助或指针。
答案 0 :(得分:5)
WebResource.entity(...)方法不会改变您的webResource实例...它会创建并返回保存更改的Builder对象。您对.post的调用通常是从Builder对象而不是从WebResource对象执行的。当所有请求被链接在一起时,这种转变很容易被掩盖。
public void sendExample(Example example) {
WebResource webResource = this.client.resource(this.url);
Builder builder = webResource.type(MediaType.APPLICATION_JSON);
builder.accept(MediaType.APPLICATION_JSON);
builder.post(Example.class, example);
return;
}
这是使用链接的相同示例。它仍在使用Builder,但不太明显。
public void sendExample(Example example) {
WebResource webResource = this.client.resource(this.url);
webResource.type(MediaType.APPLICATION_JSON)
.accept(MediaType.APPLICATION_JSON)
.post(Example.class, example);
return;
}
答案 1 :(得分:3)
如果您的网络服务生成JSON,您必须使用accept()
方法在您的客户端处理它:
ClientResponse response = webResource.accept(MediaType.APPLICATION_JSON).post(searchQuery, MediaType.APPLICATION_JSON);
ListWrapper listWrapper = response.getEntity(ListWrapper.class);
试试这个并给出结果。