gpt4 book ai didi

java - 如何 Swagger 注释具有复杂对象的 Spring GET @RequestMapping

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:11:14 27 4
gpt4 key购买 nike

问题是我有一个复杂的对象作为 GET 请求的请求参数,并且在我将 Swagger 注释放入该对象之后。 Swagger UI 显示入口参数是一个主体,我必须在其中放置参数。

 body: {
"modelId": 0,
"makeId": 0
}

我的 REST Controller 看起来像这样

  @RequestMapping(method = RequestMethod.GET, value = "/model")
public SearchModelsResponse searchModels(
@ApiParam(value = "Search for something",
required = true) final ModelSearch search) {...}

和请求对象

public class ModelSearch {

@ApiParam(value = "Something important)", required = true)
private Long modelId;

@ApiParam(value = "Something else important)", required = false)
@Nullable
private Long makeId;

....
}

有没有一种方法可以正确地对其进行注释,以便 Swagger 将其显示为与请求参数一样正确,而不是作为主体构造?

最佳答案

好的,这种情况下的解决方案是手动定义参数,这可以通过 @ApiImplicitParam 注释实现。

所以结果看起来像这样。

  @ApiImplicitParams({
@ApiImplicitParam(name = "modelId", value = "this is modelId", required = true, dataType = "string", paramType = "query"),
@ApiImplicitParam(name = "makeId", value = "this is makeId", required = true, dataType = "string", paramType = "query")
})
@RequestMapping(method = RequestMethod.GET, value = "/model")
public SearchModelsResponse searchModels(
final ModelSearch search) {...}

这不是一个完美的解决方案,因为我实际上想要 Swagger 解释我的代码,但结果提供了将其显示为请求参数而不是主体构造的选项。

关于java - 如何 Swagger 注释具有复杂对象的 Spring GET @RequestMapping,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44849962/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com