当前位置:网站首页 > 后端性能优化 > 正文

swagger3配置(swagger性能)



Swagger 是一套基于 OpenAPI 规范(OpenAPI Specification,OAS)构建的开源工具,可以帮助我们设计、构建、记录以及使用 REST API。

OpenAPI规范是在2015年由OpenAPI Initiative捐赠给Linux基金会的。该规范创建了RESTful接口,可通过有效映射与之关联的所有资源和操作来轻松开发和使用API。

Swagger 主要包含了以下三个部分:

  • Swagger Editor:基于浏览器的编辑器,我们可以使用它编写我们 OpenAPI 规范。
  • Swagger UI:它会将我们编写的 OpenAPI 规范呈现为交互式的 API 文档,后文我将使用浏览器来查看并且操作我们的 Rest API。
  • Swagger Codegen:它可以通过为 OpenAPI(以前称为 Swagger)规范定义的任何 API 生成服务器存根和客户端 SDK 来简化构建过程。

Springfox的Java库套件旨在自动生成使用spring系列项目编写的JSON API的机器和人类可读规范。

Springfox的工作原理是在运行时检查应用程序,以基于Spring配置,类结构和各种编译时Java注释来推断API语义。

Springfox从最初由Marty Pitt创建的项目演变而来,并被命名为 swagger-springmvc。

通常SpringBoot项目整合swagger需要用到两个依赖:和,用于自动生成swagger文档。

  • springfox-swagger2:这个组件的功能用于帮助我们自动生成描述API的json文件
  • springfox-swagger-ui:就是将描述API的json文件解析出来,用一种更友好的方式呈现出来。

官方说明:

  • SpringFox 3.0.0 发布了,SpringFox 的前身是 swagger-springmvc,是一个开源的 API doc 框架,可以将 Controller 的方法以文档的形式展现。
  • 首先,非常感谢社区让我有动力参与这个项目。在这个版本中,在代码、注释、bug报告方面有一些非常惊人的贡献,看到人们在问题论坛上跳槽来解决问题,我感到很谦卑。它确实激励我克服“困难”,开始认真地工作。有什么更好的办法来摆脱科维德的忧郁!
  • 注意:这是一个突破性的变更版本,我们已经尽可能地保持与springfox早期版本的向后兼容性。在2.9之前被弃用的api已经被积极地删除,并且标记了将在不久的将来消失的新api。所以请注意这些,并报告任何遗漏的内容。

新特性:

  • Remove explicit dependencies on springfox-swagger2
  • Remove any @EnableSwagger2… annotations
  • Add the springfox-boot-starter dependency
  • Springfox 3.x removes dependencies on guava and other 3rd party libraries (not zero dep yet! depends on spring plugin and open api libraries for annotations and models) so if you used guava predicates/functions those will need to transition to java 8 function interfaces.

此版本的亮点:

  • Spring5,Webflux支持(仅支持请求映射,尚不支持功能端点)。
  • Spring Integration支持(非常感谢反馈)。
  • SpringBoot支持依赖性(零配置、自动配置支持)。
  • 具有自动完成功能的文档化配置属性。
  • 更好的规范兼容性与2.0。
  • 支持OpenApi 3.0.3。
  • 零依赖。几乎只需要spring-plugin,swagger-core ,现有的swagger2注释将继续工作并丰富openapi3.0规范。

兼容性说明:

  • 需要Java 8
  • 需要Spring5.x(未在早期版本中测试)
  • 需要SpringBoot 2.2+(未在早期版本中测试)

注意:

应用主类增加注解,删除之前版本的SwaggerConfig.java。

启动项目,访问地址

附:2.x版本中访问的地址的为

Maven项目中引入依赖:

application.yml配置

使用@EnableOpenApi注解,启用swagger配置

自定义swagger配置类SwaggerProperties

一个完整详细的springfox swagger配置示例:

  • @Api:用在controller类,描述API接口
  • @ApiOperation:描述接口方法
  • @ApiModel:描述对象
  • @ApiModelProperty:描述对象属性
  • @ApiImplicitParams:描述接口参数
  • @ApiResponses:描述接口响应
  • @ApiIgnore:忽略接口方法

项目Demo:springfox-swagger

效果图:

SpringBoot基于OpenAPI3_ci

到此这篇swagger3配置(swagger性能)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • yarn队列配置(yarn队列资源优化)2025-03-03 18:18:09
  • 重绘和回流(重绘和回流对性能的影响)2025-03-03 18:18:09
  • 重绘和重排(重绘重排优化)2025-03-03 18:18:09
  • Bytebuffer 性能(bytebuffer compact)2025-03-03 18:18:09
  • ripro优化(prey优化)2025-03-03 18:18:09
  • 天国拯救战斗系统优化mod(天国拯救战斗系统真垃圾)2025-03-03 18:18:09
  • 阻塞队列和非阻塞队列 性能区别(什么叫阻塞队列)2025-03-03 18:18:09
  • 2258xt和2259xt区别(2259xt性能)2025-03-03 18:18:09
  • 重绘和回流如何优化(重绘和回流的优化)2025-03-03 18:18:09
  • rmsprop优化器优缺点(rbo优化器)2025-03-03 18:18:09
  • 全屏图片