Jul*_*ien 5 spring swagger-ui springfox
我想在我的休息服务的自动生成的swagger ui文档中添加一个头参数字段.我使用Spring和Springfox.
public ResponseEntity<User> saveNewUser(
@ApiParam(value = "the user to create", required = true) @RequestBody User user) throws RestServiceException {
userService.save(user);
return new ResponseEntity<User>(user, HttpStatus.OK);
}
Run Code Online (Sandbox Code Playgroud)
如你所见,我已经有了一个体型参数.我只想添加一个头类型.
Eno*_*ong 11
我更喜欢使用@ApiImplicitParam
我的@RequestMapping
参数而不是函数参数,因为通常您可以在过滤器中处理标头(例如,身份验证),并且不需要该方法中的值。
此外,如果您在方法中需要它们,那么Swagger auto会为 @HeaderParam
当某些调用需要标题而其他不需要时,这种样式还提高了可读性和灵活性。
例
@PostMapping
@ApiImplicitParam(name = "Authorization", value = "Access Token", required = true, allowEmptyValue = false, paramType = "header", dataTypeClass = String::class, example = "Bearer access_token")
fun addJob(jobRequest: Job): ResponseEntity<*>{}
Run Code Online (Sandbox Code Playgroud)
如果所有或大多数为您的端点需要头,我会宁愿将其配置为看到这里
如果必须声明多个标头参数,则需要使用@ApiImplicitParams批注:
@PostMapping
@ApiImplicitParams(
@ApiImplicitParam(name = "Authorization", value = "Access Token", required = true, allowEmptyValue = false, paramType = "header", dataTypeClass = String::class, example = "Bearer access_token"),
@ApiImplicitParam(name = "X-Custom-Header", value = "A Custom Header", required = true, allowEmptyValue = false, paramType = "header", dataTypeClass = String::class, example = "my header example")
)
fun addJob(jobRequest: Job): ResponseEntity<*>{}
Run Code Online (Sandbox Code Playgroud)
我刚补充说@RequestHeader(value="myHeader") String headerStr
:
public ResponseEntity<User> saveNewUser(
@RequestHeader(value="myHeader") String headerStr,
@ApiParam(value = "the user to create", required = true) @RequestBody User user) throws RestServiceException {
userService.save(user);
return new ResponseEntity<User>(user, HttpStatus.OK);
}
Run Code Online (Sandbox Code Playgroud)
(import org.springframework.web.bind.annotation.RequestHeader;
)
您还可以使用此处描述的解决方案在文档中的每个服务上添加全局标头:Spring + Springfox + Header Parameters
小智 5
如果你有更多的头参数,那么每个 API 都会有那么多的@RequestHeader
为了避免这种情况并且您的 API 看起来很简单,您可以使用 HeaderInterceptor 来捕获标头信息。
In preHandle() , you need to extract the headerInfo in to a an Object and set it as RequestAttribute
public class MyHeaderInterceptor extends HandlerInterceptorAdapter {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
HeaderVo headerVo = HeaderVo.createReqHeaderinput(
request.getHeader("authorization"),
request.getHeader("contentType"),
request.getHeader("myHeaderParam0"),
request.getHeader("myHeaderParam1"),
request.getHeader("myHeaderParam3"),
request.getHeader("myHeaderParam4"),
request.getHeader("myHeaderParam5")
);
// You can do any validation of any headerInfo here.
validateHeader(headerVo);
request.setAttribute("headerName", headerVo);
return true;
}
}
Run Code Online (Sandbox Code Playgroud)
您的 API 将如下所示,带有 @RequestAttribute("headerName")
public @ResponseBody
ResponseEntity<MyResponse> getSomeApi(
//Headers common for all the API's
@RequestAttribute("headerName") HeaderVo header ,
@ApiParam(value = "otherAPiParam", required = true, defaultValue = "")
@PathVariable(value = "otherAPiParam") String otherAPiParam,
@ApiParam(value = "otherAPiParam1", required = true, defaultValue = "")
@RequestParam(value = "otherAPiParam1") String otherAPiParam1,
@ApiParam(value = "otherAPiParam2, required = true, defaultValue = "")
@RequestParam(value = "otherAPiParam2") String otherAPiParam2
) throws MyExcp {
....
}
Run Code Online (Sandbox Code Playgroud)
您的 Swagger 仍然应该描述 API 的所有标头,为此您可以在 swagger Docket、SwaggerConfig 中添加参数 请注意忽略的参数类型,我们提到忽略 HeaderVo,因为这是应用程序内部的。招摇不需要表明
@Bean
public Docket postsApi() {
//Adding Header
ParameterBuilder aParameterBuilder = new ParameterBuilder();
List<Parameter> aParameters = new ArrayList<Parameter>();
aParameters.clear();
aParameterBuilder.name("myHeaderParam0").modelRef(new ModelRef("string")).parameterType("header").required(false).build();
aParameters.add(aParameterBuilder.build());
aParameterBuilder.name("myHeaderParam1").modelRef(new ModelRef("string")).parameterType("header").required(false).build();
aParameters.add(aParameterBuilder.build());
....
....
return new Docket(DocumentationType.SWAGGER_2).groupName("public-api")
.apiInfo(apiInfo()).select().paths(postPaths()).build().ignoredParameterTypes(HeaderVo.class).globalOperationParameters(aParameters);
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
15309 次 |
最近记录: |