我已经将Swagger添加到我的Spring Boot 2应用程序中:
这是我的Swagger配置:
@Configuration
@EnableSwagger2
public class SwaggerConfig {
@Bean
public Docket api() {
// @formatter:off
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.any())
.paths(PathSelectors.any())
.build();
// @formatter:on
}
}
这是Maven依赖:
<!-- Swagger2 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.8.0</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.8.0</version>
</dependency>
例如,当我尝试调用http://localhost:8080/api/actuator/auditevents时,它会失败,并显示以下错误:
TypeError: Failed to execute 'fetch' on 'Window': Request with GET/HEAD method cannot have body.
我做错了什么?如何修复它?
发布于 2019-07-24 03:13:40
我遇到了这个问题。下面是我解决这个问题的方法:
我有一个这样的方法:
[HttpGet]
public IEnumerable<MyObject> Get(MyObject dto)
{
...
}
然后我就得到了错误。我相信swagger UI将Get参数解释为FromBody,所以它使用了curl -d
标志。我添加了FromQuery装饰器,问题就解决了:
[HttpGet]
public IEnumerable<MyObject> Get([FromQuery]MyObject dto)
{
...
}
仅供参考,这也改变了该方法的UI体验。您将为参数对象的每个属性提供一个表单域,而不是提供json。
发布于 2018-09-06 01:03:11
不要在Get方法中传递方法类型。
let res = await fetch("http://localhost:8080/employee_async",{
method: "POST",
body:JSON.stringify(data),
mode:"cors",
headers: {"Content-type":"application/json;charset=utf-8"}})
这仅用于post,如果我们没有分配任何被自动视为Get方法的方法类型节点
发布于 2019-10-25 23:52:26
要避免此错误,请确保使用@RequestParam注释控制器中的参数,如
@GetMapping("/get")
public Response getData(@RequestParam String param)
https://stackoverflow.com/questions/48749252
复制相似问题