镜头的奥秘《分镜头脚本创作》
《分镜头脚本创作》带你一起探寻镜头中的世界。...
2023-06-11
小伙伴们都知道,现在 Java 开发基本上都是前后端分离模式了。既然要搞前后端分离,就离不开在线接口文档,而要想实现在线接口文档,我们又有很多不同的选择,其中 Swagger 和 SpringDoc 是开源领域的两个重要产品。今天百泽老师,就来手把手地教大家如何使用这两个工具!并且来看看这两个工具哪个更好?
接下来小马哥给大家分别介绍一下这两个产品。
一. Swagger
Swagger在2020年其实就更新到 3.0 版本了,现在大家如果在最新版的 Spring Boot 中使用老版本的 Swagger,多多少少都会遇到一些兼容性的问题。既然Swagger3 迟早都要学,那不如就今天开始学吧!
今天我们就来看看,在 Spring Boot2.7.2 中如何使用 Swagger3。
1. 添加依赖
首先我们创建一个 Spring Boot 项目,并引入 Swagger3 的核心依赖包,如下:
<dependency> <groupId>io.springfox</groupId> <artifactId>Springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency>
以前在旧版的 Swagger 中,我们需要添加的依赖包有两个,现在只需要添加一个依赖即可。
2. 核心配置
接下来我们在启动类上添加两个注解,开启Swagger功能。
@SpringBootApplication //开启swagger @EnableSwagger2 @EnableOpenAPI @EnableWebMvc public class SwaggerApplication { public static void main(String[] args) { SpringApplication.run(SwaggerDemoApplication.class, args); } }
现在准备工作就 OK 啦,Swagger 文档已经可以自动生成了,并且也可以在线访问了。
接下来让我们可以启动项目,然后在浏览器中输入如下地址:
http://localhost:8080/swagger-ui/index.html
现在我们就可以查看自动生成的 Swagger 文档了。
如果大家用过以前旧版的 Swagger,应该可以看出来,这个访问地址跟以前旧版的 Swagger 访问地址不太一样。
大家看到,默认的接口中有一个是 BasicErrorController,这个接口是 Spring Boot 默认提供的异常处理器。由于我们现在没有设置 Swagger 要扫描哪些包,所以默认所有暴露的接口都被扫描了,所以就连同这个默认的异常处理接口一起被扫描出来了。
如果我们需要对这个接口做一些定制,也是可以的,如下所示:
@Configuration public class Swagger2Config { @Bean Docket docket() { return new Docket(DocumentationType.OAS_30) //配置网站的基本信息 .apiInfo(new ApiInfoBuilder() //网站标题 .title("锋迷商城项目在线接口文档") //标题后面的版本号 .version("v1.0") .description("锋迷商城项目接口文档") //联系人信息 .contact(new Contact("qf", "http://www.qfedu.com", "111@qq.com")) .build()) .select() //指定接口的位置 .apis(RequestHandlerSelectors.basePackage("com.qfedu.swagger_demo.controller")) .build(); } }
配置完成之后,Swagger的网页就会更新了。
3. 接口配置
默认的接口信息是根据代码生成的,很多都是英文,这并不符合我们的日常使用习惯,所以我们还是想把接口信息定制成中文的,我们来看下:
@RestController @Api(tags = "用户管理相关接口") @RequestMapping("/user") public class UserController { @PostMapping("/") @ApiOperation("添加用户的接口") @ApiImplicitParams({ @ApiImplicitParam(name = "username", value = "用户名", defaultValue = "李四"), @ApiImplicitParam(name = "address", value = "用户地址", defaultValue = "深圳", required = true) }) public RespBean addUser(String username, @RequestParam(required = true) String address) { return new RespBean(); } @GetMapping("/") @ApiOperation("根据id查询用户的接口") @ApiImplicitParam(name = "id", value = "用户id", defaultValue = "99", required = true) public User getUserById(@PathVariable Integer id) { User user = new User(); user.setId(id); return user; } @PutMapping("/{id}") @ApiOperation("根据id更新用户的接口") public User updateUserById(@RequestBody User user) { return user; } }
这些都是 Swagger 的常用注解,我们来逐个看看都有什么功能:
@Api 注解可以用来描述一个 Controller 整体功能;@ApiOperation 注解用来描述一个方法的具体功能;@ApiImplicitParam 注解用来描述一个方法的参数含义,我们可以通过这个注解来配置参数的中文含义,或者给参数设置默认值,这样就可以在接口测试的时候可以避免手动输入值,提高测试效率;如果某一个接口方法有多个参数,那么就需要使用多个 @ApiImplicitParam 注解来描述接口参数,多个 @ApiImplicitParam 注解放在一个 @ApiImplicitParams 注解中集中管理即可;@ApiImplicitParam 注解中虽然可以指定参数是必填的,但是却不能代替 @RequestParam(required = true) ,前者的必填只是在 Swagger 框架内必填,抛弃了 Swagger ,这个限制就没用了,所以假如开发者需要指定一个参数必填, @RequestParam(required = true) 注解还是不能省略;如果参数是一个对象(例如上文的更新接口),对于参数的描述也可以放在实体类中。例如下面一段代码:@ApiModel public class User { @ApiModelProperty(value = "用户id") private Integer id; @ApiModelProperty(value = "用户名") private String username; @ApiModelProperty(value = "用户地址") private String address; //getter/setter }
配置完成后,再去刷新页面,就可以看到刚刚配置的文档信息啦。
二. SpringDoc
SpringDoc 是 OpenApi 的另一个实现,我们前面第一小节使用的 Swagger 其实也是 OpenAPI 的一个实现。OpenApi 是业界的一个 API 文档标准,是一个规范。相比 Swagger,SpringDoc的功能更有规范和强大,SpringDoc 具有如下特性:
OpenAPI 3;Spring Boot全系列都支持;JSR-303中提供的一些注解,例如 @NotNull、@Min、@Max 以及 @Size 等;Swagger-ui:SpringDoc 提供的接口 JSON ,也可以通过 Swagger-ui 展示出来。OAuth 21. 添加依赖
当我们使用 SpringDoc 的时候,如果只是想生成文档 JSON,那么只需要添加如下依赖即可:
<dependency> <groupId>org.springdoc</groupId> <artifactId>springdoc-openapi-webmvc-core</artifactId> <version>1.6.9</version> </dependency>
此时就会针对项目中的接口,自动生成接口对应的 JSON 文档。这个单纯的 JSON 格式看着肯定不是很方便,我们还是得有个页面,接下来添加如下依赖,即可通过网页来展示上面的 JSON 数据了:
<dependency> <groupId>org.springdoc</groupId> <artifactId>springdoc-openapi-ui</artifactId> <version>1.6.9</version> </dependency>
这个网页说白了其实就是 Swagger UI。
2. 从 Swagger 到 SpringDoc
如果有小伙伴已经在项目中使用 Swagger了,其实也可以非常方便地切换到 SpringDoc 上面来,切换的时候,首先引入 SpringDoc 依赖:
<dependency> <groupId>org.springdoc</groupId> <artifactId>springdoc-openapi-ui</artifactId> <version>1.6.9</version> </dependency>
Swagger 和 SpringDoc 注解的对应关系如下:
@Api → @Tag@ApiIgnore → @Parameter(hidden = true) or @Operation(hidden=false) or @Hidden@ApiImplicitParam → @Parameter@ApiImplicitParams → @Parameters@ApiModel → @Schema@ApiModelProperty(hidden = true) → @Schema(acc essMode = READ_ONLY)@ApiModelProperty → @Schema@ApiOperation(value = "foo", notes = "bar") → @Op eration(summary = "foo", description = "bar")@ApiParam → @Parameter@ApiResponse(code = 404, message = "foo") → @A piResponse(responseCode = "404", description = "foo")按照这样的方式,我们更换注解就可以轻松地切换到SpringDoc上去啦。
三. 小结
好啦,现在小马哥就把Swagger 和 SpringDoc 都给大家介绍完了,你更喜欢哪个呢?可以在评论区告诉我哦。关注互联网架构小马哥,干货天天都不断!
以上内容就是为大家推荐的doc怎么打开(你会用哪个)最佳回答,如果还想搜索其他问题,请收藏本网站或点击搜索更多问题
内容来源于网络仅供参考版权声明:所有来源标注为小樱知识网www.xiaoyin02.com的内容版权均为本站所有,若您需要引用、转载,只需要注明来源及原文链接即可。
本文标题:doc怎么打开(你会用哪个)
本文地址:https://www.xiaoyin02.com/smjd/850140.html
相关文章
热点文章
2021年独生子女补贴新政策是真的吗(独生子女证有有效期吗)
2021年国庆节阅兵仪式几点开始几点结束(2021年国庆节还有阅兵吗)
鼠目寸光一点红是什么生肖动物(鼠目寸光一点红)指什么生肖,紧密
k0到k9的玩法大全(强制gc的玩法和注意事项)
入土为安是什么生肖《入土为安》打一个生肖动物,词语解释
浙江12月底全面停工是真的吗(浙江什么时候放假停工)
如何做t(t怎么把p做哭)
北京口碑最差的三甲医院(北京301医院最擅长什么)