我使用JAX-RS + Jersey来使用网络服务请求,杰克逊用它来翻译JSON数据:
@Path("/")
public class JAXRSRestController {
@Path("/jsonRequest")
@POST
@Consumes(MediaType.APPLICATION_JSON)
public Response submitJsonRequest(SampleObject sampleObject, @Context HttpHeaders headers)
{
Ack ack = new Ack();
ack.setUniqueId(sampleObject.getId());
ack.setType(sampleObject.getName());
return Response.ok().entity(ack).build();
}
}
如果请求采用以下格式,则不会消耗:
{
"sampleObject": {
"id": "12345",
"name": "somename"
}
}
但如果请求采用以下格式,则会被使用:
{
"id": "12345",
"name": "somename"
}
如何让控制器也使用Json根元素?
SampleObject类:
import org.codehaus.jackson.map.annotate.JsonRootName;
@XmlRootElement(name = "sampleObject")
@JsonRootName(value = "sampleObject")
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "SampleObject", propOrder = {
"id",
"name"
})
public class SampleObject
{
protected String id;
protected String name;
public SampleObject(){}
public SampleObject(String id, String name) {
this.id = id;
this.name = name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
的web.xml:
<?xml version="1.0" encoding= "UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" >
<display-name>Wed Application</display-name>
<servlet>
<servlet-name>Jersey RESTFul WebSerivce</servlet-name>
<servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>com.sun.jersey.config.property.packages</param-name>
<param-value>com.jaxrs.rest</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>Jersey RESTFul WebSerivce</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
</web-app>
答案 0 :(得分:5)
我能想到两种方法。如果这在您的应用程序中很常见,我建议您在ObjectMapper
上启用解包功能。如果这是一次性情况,则包装器对象不是一个糟糕的选择。
@JsonRootName
仅适用于在ObjectMapper
上启用展开功能的情况。您可以使用反序列化功能完成此操作。请注意,这将解包所有请求:
public CustomObjectMapper() {
super();
enable(DeserializationFeature.UNWRAP_ROOT_VALUE);
}
如果您尚未注册自定义ObjectMapper
,则需要添加provider以使用Jersey注册自定义配置。 This answer解释了如何实现这一目标。
如果您不想全局展开,可以创建一个简单的包装器对象并省略@JsonRootName
注释:
public class SampleObjectWrapper {
public SampleObject sampleObject;
}
然后更新您的资源方法签名以接受包装器:
public Response submitJsonRequest(SampleObjectWrapper sampleObjectWrapper, @Context HttpHeaders headers)