如何在RESTful POST方法中访问参数

我的POST方法看起来像这样:

@POST

@Consumes({"application/json"})

@Path("create/")

public void create(String param1, String param2){

System.out.println("param1 = " + param1);

System.out.println("param2 = " + param2);

}

当我在Netbeans中创建Jersey客户时,调用post方法的方法如下所示:

public void create(Object requestEntity){

webResource.path("create").type(MediaType.APPLICATION_JSON).post(requestEntity);

}

运行此测试时:

@Test

public void hello(){

String json = "{param1=\"hello\",param2=\"hello2\"}";

this.client.create(json);

}

它在服务器中提供以下输出:

INFO: param1 = {param1="hello",param2="hello2"}

INFO: param2 =

我需要更改什么才能使参数给出正确的值?

回答:

你的@POST方法应该接受JSON对象而不是字符串。Jersey使用JAXB支持封送和拆封JSON对象(有关详细信息,请参阅jersey文档)。创建一个类似的类:

@XmlRootElement

public class MyJaxBean {

@XmlElement public String param1;

@XmlElement public String param2;

}

然后,你的@POST方法将如下所示:

@POST @Consumes("application/json")

@Path("/create")

public void create(final MyJaxBean input) {

System.out.println("param1 = " + input.param1);

System.out.println("param2 = " + input.param2);

}

此方法希望接收JSON对象作为HTTP POST的主体。JAX-RS input在此情况下将HTTP消息的内容主体作为未注释的参数传递。实际消息如下所示:

POST /create HTTP/1.1

Content-Type: application/json

Content-Length: 35

Host: www.example.com

{"param1":"hello","param2":"world"}

由于明显的原因,以这种方式使用JSON很普遍。但是,如果要使用JavaScript以外的其他方式生成或使用它,则必须注意正确地转义数据。在JAX-RS中,你将使用MessageBodyReader和MessageBodyWriter来实现此目的。我相信Jersey已经具有所需类型(例如Java原语和JAXB包装类)以及JSON的实现。JAX-RS支持许多其他方法来传递数据。这些不需要创建新的类,因为使用简单的参数传递来传递数据。

HTML

参数将使用@FormParam进行注释:

@POST

@Path("/create")

public void create(@FormParam("param1") String param1,

@FormParam("param2") String param2) {

...

}

浏览器将使用“ application / x-www-form-urlencoded”对表单进行编码。JAX-RS运行时将负责解码主体并将其传递给方法。这是你在网上看到的内容:

POST /create HTTP/1.1

Host: www.example.com

Content-Type: application/x-www-form-urlencoded;charset=UTF-8

Content-Length: 25

param1=hello&param2=world

在这种情况下,内容是URL编码的。

如果你不知道FormParam的名称,则可以执行以下操作:

@POST @Consumes("application/x-www-form-urlencoded")

@Path("/create")

public void create(final MultivaluedMap<String, String> formParams) {

...

}

如果要通过HTTP标头传递参数,可以使用@HeaderParam批注:

@POST

@Path("/create")

public void create(@HeaderParam("param1") String param1,

@HeaderParam("param2") String param2) {

...

}

这是HTTP消息的样子。请注意,此POST没有正文。

POST /create HTTP/1.1

Content-Length: 0

Host: www.example.com

param1: hello

param2: world

我不会将此方法用于广义参数传递。不过,如果你需要访问特定HTTP标头的值,这确实非常方便。

此方法主要用于HTTP GET,但同样适用于POST。它使用@QueryParam批注。

@POST

@Path("/create")

public void create(@QueryParam("param1") String param1,

@QueryParam("param2") String param2) {

...

}

与先前的技术一样,通过查询字符串传递参数不需要消息正文。这是HTTP消息:

POST /create?param1=hello&param2=world HTTP/1.1

Content-Length: 0

Host: www.example.com

你必须特别小心,才能在客户端正确编码查询参数。由于某些代理实施的URL长度限制以及与编码相关的问题,使用查询参数可能会出现问题。

HTTP路径参数

路径参数与查询参数相似,不同之处在于它们嵌入在HTTP资源路径中。今天,这种方法似乎很受欢迎。由于路径是真正定义HTTP资源的路径,因此对HTTP缓存有影响。该代码看起来与其他代码略有不同,因为已修改@Path批注,并使用@PathParam:

@POST

@Path("/create/{param1}/{param2}")

public void create(@PathParam("param1") String param1,

@PathParam("param2") String param2) {

...

}

该消息与查询参数版本相似,不同之处在于消息的任何地方均不包含参数名称。

POST /create/hello/world HTTP/1.1

Content-Length: 0

Host: www.example.com

此方法与查询参数版本共享相同的编码问题。 路径段的编码方式不同,因此你也必须在此处格外小心。

如你所见,每种方法各有利弊。选择通常由你的客户决定。如果你正在提供FORM基于HTML的HTML页面,请使用@FormParam。如果你的客户端基于JavaScript + HTML5,则你可能希望使用基于JAXB的序列化和JSON对象。这些MessageBodyReader/Writer实现应为你处理必要的转义操作,以免出错。如果你的客户端基于Java,但没有良好的XML处理器(例如Android),则我可能会使用FORM编码,因为内容主体比URL更易于正确生成和编码。希望这个微型Wiki条目可以阐明JAX-RS支持的各种方法。

注意:为了全面披露,我实际上尚未使用Jersey的此功能。因为我们已经部署了许多JAXB + JAX-RS应用程序,并且正在向移动客户端空间迁移,所以我们对此进行了修补。JSON比XML更好地适合HTML5或基于jQuery的解决方案。

以上是 如何在RESTful POST方法中访问参数 的全部内容, 来源链接: utcz.com/qa/432749.html

回到顶部