我想发布一个帖子给Jersey Rest服务。这样做的标准方法是什么?
@Post
@Consumes(MediaType.Application_xml)
public Response method(??){}
答案 0 :(得分:6)
假设你有一个java bean说一个员工bean,比如。添加标签告诉
@XmlRootElement (name = "Employee")
public class Employee {
String employeeName;
@XmlElement
public String getEmployeeName() {
return employeeName;
}
public void setEmployeeName(String employeeName) {
this.employeeName = employeeName;
}
}
@XmlRootElement告诉它这将是xml中的主标记。在这种情况下,您也可以为主标签指定名称。
@XmlElement告诉这将是根标记
中的子标记比如说,在post请求中作为body的一部分出现的示例xml看起来像
<?xml version="1.0" encoding="UTF-8"?>
<Employee>
<employeeName>Jack</employeeName>
</Employee>
在编写Web服务以接受这样的xml时,我们可以编写以下方法。
@POST
@Path("/post")
@Consumes(MediaType.APPLICATION_XML)
@Produces(MediaType.APPLICATION_XML)
public Response getEmployee(Employee employee) {
employee.setEmployeeName(employee.getEmployeeName() + " Welcome");
return Response.status(Status.OK).entity(employee).build();
}
在调用此服务时,您将获得以下xml作为响应的一部分。
<Employee>
<employeeName> Jack Welcome </employeeName>
</Employee>
使用@Xml ...注释,解组和编组请求和响应对象变得非常容易。
通过使用MediaType.APPLICATION_JSON而不是APPLICATION_XML,可以对JSON输入和JSON输出采取类似的方法
因此,对于xml作为输入,您可以将xml作为输出作为http响应的一部分。 希望这会有所帮助。
答案 1 :(得分:4)
以下是后期操作的示例:
@POST
@Consumes({"application/xml", "application/json"})
public Response create(@Context UriInfo uriInfo, Customer entity) {
entityManager.persist(entity);
entityManager.flush();
UriBuilder uriBuilder = uriBuiler.path(String.valueOf(entity.getId()));
return Response.created(uriBuilder.build()).build();
}