SpringBoot集成Swagger接口文档/测试

编程入门 行业动态 更新时间:2024-10-13 06:12:56

SpringBoot集成Swagger<a href=https://www.elefans.com/category/jswz/34/1771365.html style=接口文档/测试"/>

SpringBoot集成Swagger接口文档/测试

文章目录

  • Swagger 介绍
  • Swagger 使用
  • 常用注解


Swagger 介绍

使用 Swagger 你只需要按照它的规范去定义接口及接口相关的信息,就可以做到生成接口文档,以及在线接口调试页面。官网:/

Knife4j 是为 Java MVC 框架集成 Swagger 生成 Api 文档的增强解决方案。(对 Swagger 进行了封装,简化了相应操作)

Swagger 使用

  1. 导入 Knife4j 的 maven 坐标
  2. 在配置类中加入 Knife4j 相关配置
  3. 设置静态资源映射,否则接口文档页面无法访问



knife4j坐标

<dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-spring-boot-starter</artifactId>
</dependency>

WebMvcConfiguration 中进行配置

/*** 配置类,注册web层相关组件*/
@Configuration
@Slf4j
public class WebMvcConfiguration extends WebMvcConfigurationSupport {@Autowiredprivate JwtTokenAdminInterceptor jwtTokenAdminInterceptor;@Autowiredprivate JwtTokenUserInterceptor jwtTokenUserInterceptor;/*** 注册自定义拦截器** @param registry*/protected void addInterceptors(InterceptorRegistry registry) {log.info("开始注册自定义拦截器...");registry.addInterceptor(jwtTokenAdminInterceptor).addPathPatterns("/admin/**").excludePathPatterns("/admin/employee/login");registry.addInterceptor(jwtTokenUserInterceptor).addPathPatterns("/user/**").excludePathPatterns("/user/user/login").excludePathPatterns("/user/shop/status").excludePathPatterns("/user/order/paySuccess");}/*** 通过knife4j生成接口文档* @return*/@Beanpublic Docket docket1() {ApiInfo apiInfo = new ApiInfoBuilder().title("苍穹外卖项目接口文档").version("2.0").description("苍穹外卖项目接口文档").build();Docket docket = new Docket(DocumentationType.SWAGGER_2).groupName("管理端接口").apiInfo(apiInfo).select().apis(RequestHandlerSelectors.basePackage("com.sky.controller.admin")).paths(PathSelectors.any()).build();return docket;}@Beanpublic Docket docket2() {ApiInfo apiInfo = new ApiInfoBuilder().title("苍穹外卖项目接口文档").version("2.0").description("苍穹外卖项目接口文档").build();Docket docket = new Docket(DocumentationType.SWAGGER_2).groupName("用户端接口").apiInfo(apiInfo).select().apis(RequestHandlerSelectors.basePackage("com.sky.controller.user")).paths(PathSelectors.any()).build();return docket;}/*** 设置静态资源映射* @param registry*/protected void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler("/doc.html").addResourceLocations("classpath:/META-INF/resources/");registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");}
}

访问 xxx/doc.html 可以看到相应的接口文档页面

可以在此处添加全局参数,比如 token

通过调试发送请求,测试接口功能

常用注解

@Api 用在Controller 类上:

@ApiOperation 用在Controller 的方法上:

@ApiModel 用在 dto、vo、entity 类上:

@ApiModelProperty 用在实体类属性上

更多推荐

SpringBoot集成Swagger接口文档/测试

本文发布于:2023-11-16 19:16:42,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1631258.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:接口   文档   测试   SpringBoot   Swagger

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!