如何使用可选参数创建 REST API?

2022-09-03 12:32:16

我需要实现一个具有这些路径参数的API。

@Path("/job/{param1}/{optional1}/{optional2}/{param2}")

第二个和第三个参数可以可选吗?因此,客户端不需要传递这些,而必须传递第一个和最后一个。

如果这是不可能的,那么是否建议以这种方式重新排列参数?

@Path("/job/{param1}/{param2}/{optional1}/{optional2}")

如何提供可选参数?


答案 1

将可选路径参数转换为查询参数可能会更容易。然后,如果需要,您可以使用:@DefaultValue

@GET @Path("/job/{param1}/{param2}")
public Response method(@PathParam("param1") String param1,
    @PathParam("param2") String param2,
    @QueryParam("optional1") String optional1,
    @QueryParam("optional2") @DefaultValue("default") String optional2) {
  ...
}

然后,您可以使用仅传递所需的可选参数来调用它。/job/one/two?optional1=test


答案 2

您可以匹配在 REST 请求中结束的整个路径

@Path("/location/{locationId}{path:.*}")
public Response getLocation(
    @PathParam("locationId") int locationId,
    @PathParam("path") String path) {
    //your code
}

现在路径变量包含整个路径location/{locationId}

您还可以使用正则表达式使路径可选。

@Path("/user/{id}{format:(/format/[^/]+?)?}{encoding:(/encoding/[^/]+?)?}")
public Response getUser(
    @PathParam("id") int id,
    @PathParam("format") String format,
    @PathParam("encoding") String encoding) {
    //your code
}

现在,如果您格式化和编码将是可选的。你没有给任何值,它们将是空的。