springboot集成Swagger的方法(让你拥有属于自己的api管理器)
作者:沉默着忍受 发布时间:2023-11-08 20:39:15
很多朋友问小编springboot项目中怎么集成Swagger呢?
swagger世界上最好的api管理工具
前言
我们为什么要使用api管理工具?在大型的项目中,如果你有非常多的接口需要统一管理,或者需要进行接口测试,那么我们通常会在繁杂地api中找到需要进行测试或者管理的接口。当然,我们可以使用postman或者谷歌浏览器自带的api Talend api Tester 。 但是这些工具往往只是对单个接口进行测试管理,是我们主动去人为管理的,那么为了减轻管理测试的人力成本,swagger便应运而生。
一、swagger是什么?
我先通过官方的解释去给各位读者描述: Swagger™的目标是为REST APIs 定义一个标准的,与语言无关的接口,使人和计算机在看不到源码或者看不到文档或者不能通过网络流量检测的情况下能发现和理解各种服务的功能。当服务通过Swagger定义,消费者就能与远程的服务互动通过少量的实现逻辑。类似于低级编程接口,Swagger去掉了调用服务时的很多猜测。 浏览 Swagger-Spec 去了解更多关于Swagger 项目的信息,包括附加的支持其他语言的库。
相信看完你还是云里雾里,沉默带你认真解析一下:
1.1 为什么swagger开始流行
早期api高度依赖
随着技术的不断迭代,传统的企业生产方式已经开始出现问题。在早先后端开发和前端开发处于一个不平衡的状态,前后端依赖的api,往往在开发时期就沟通好了,并且前端高度依赖于后端给予的接口,并且根据后端进行开发。所以早期我们很多人崇拜后端开发工程师,之前postman很好的体现了其功能的优点。
前后端分离成为现在主流
早期的前后端在融合的项目,已经不能满足现在的业务模式。现在的前端技术也越看越崛起了。现在的后台开发的结构是j交互层,逻辑处理层,数据层。而这些,好家伙,前端崛起了!出现了vue等一些优秀的前端框架。前端结构分为了前端模板,数据注入。正因为前后端的分离,前端可以直接注入自己想要的接口返回值,而不用管后端通过api给予他支持。
前后端分离,接口需要及时协同
因为前端和后端分开开发项目,如果需求需要改变,前端需要在页面展示更多的信息:例如:当前页面需要username,email,phone展示。前端可以通过模拟该数据,就可以得到效果
data:{
username:'沉默着忍受',
email:'gdysds@126.com',
phone:'110',
}
但是如果现在我需要展示我的兴趣爱好,那么我就要加一条aihao:‘打游戏'
data:{
username:'沉默着忍受',
email:'gdysds@126.com',
phone:'110',
aihao:'打游戏'
}
假设我们的接口为api/mytest/mydata 前端请求后端:
const {data :res} = await this.$http.post("api/mytest/mydata"); //后端请求接口
if (res !=null ) {
this.data = res.data; //将前端data,替换为后端返回的data;
}
else{
this.$message.error("数据获取失败!!!");
}
但是现在返回的数据中没有 aihao:‘打游戏',那么这个时候前端就要去怪后端没有提供了,后端只能又要加工作量了。搞不好还打起来,哈哈哈!在一些小的公司就没有用swagger,而是通过git管理工具,通过文档进行api的管理,那么在开发时只要git就可以了。但是如果项目里集成了swagger,还至于吗。
二、swagger集成在springboot
1.1 maven引入依赖
代码如下(示例):
SpringBoot集成Swagger => springfox,两个jar包
Springfox-swagger2
swagger-springmvc
使用Swagger
要求:jdk 1.8 + 否则swagger2无法运行
步骤:
1、新建一个SpringBoot-web项目
2、添加Maven依赖
在pom.xml中引入依赖:
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
2.2 编写Controller层,测试确保运行成功
代码如下(示例):要保证swagger有可以生成的api.
2.3 在Utils工具包中引入swagger配置
要使用Swagger,我们需要编写一个配置类-SwaggerConfig来配置 Swagger
@Configuration //配置类
@EnableSwagger2// 开启Swagger2的自动配置
public class SwaggerConfig {
}
运行springboot项目,访问本地:http://localhost:8080/swagger-ui.html
这里我们基本上是可以使用了,但是很多配置都是默认的,所以我们要进一步配置
2.4 swagger的详细配置
我自己放我的配置,拿来即用!我已经写好注释!
package com.naughty.userlogin02.util;
import org.omg.CORBA.Environment;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Profiles;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import java.util.ArrayList;
@Configuration //配置类
@EnableSwagger2// 开启Swagger2的自动配置
public class SwaggerConfig {
@Bean
public Docket docket() {
// 设置要显示swagger的环境
// 通过 enable() 接收此参数判断是否要显示
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
// .enable(false) //配置是否启用Swagger,如果是false,在浏览器将无法访问
.select()// 通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口
.apis(RequestHandlerSelectors.basePackage("com.naughty.userlogin02.controller"))
//配置你想在那个controller层生产接口文档
.paths(PathSelectors.ant("/search/**"))
// 配置如何通过path过滤,即这里只扫描请求以/kuang开头的接口
.build();
}
//配置文档信息
private ApiInfo apiInfo() {
Contact contact = new Contact("沉默这忍受", "https://blog.csdn.net/ILOVEMYDEAR", "hjj2857154359@126.com");
return new ApiInfo(
"Cartest", // 标题
"索引测试管理api", // 描述
"v1.0", // 版本
"https://blog.csdn.net/ILOVEMYDEAR", // 组织链接
contact, // 联系人信息
"Apach 2.0 许可", // 许可
"许可链接", // 许可连接
new ArrayList<>()// 扩展
);
}
}
还是启动项目,并且访问:http://localhost:8080/swagger-ui.html
接口管理演示:
这就是swagger的基本使用
总结 下一期带你了解swagger注解的用法!关注我,教你走进程序员的世界
来源:https://blog.csdn.net/ILOVEMYDEAR/article/details/121377685


猜你喜欢
- 在装2个不同版本JDK时遇到了这个问题,在网上钩了一吧!查到一个讲解比较好的资料。一:要解决的问题我们在尝鲜 JDK1.5 的时候,相信不少
- 前言这几天在做一个小工具app,结果在fragment里面动态申请权限提示原有的申请方法已经弃用,还画了很明显的删除线。。。这叫一个强迫症的
- 本文实例讲述了Android控件Tween动画(补间动画)实现方法。分享给大家供大家参考,具体如下:Android动画中的Tween动画:是
- Java 多线程方法详解startstart方法 启动线程 在start方法中调用start0方法,而start0是一个
- 我们在安装某个APP的时候,基本都会有一个引导页的提示,他们可以打广告,或者介绍新功能的加入和使用说明等。一般都支持滑动并且下面有几个点,显
- Android的文件存储,有I/O流的方式存储,与java一样,还有一种Android自己的SharePreferences存储方法。下面看
- 本文实例讲述了C#实现对文件进行加密解密的方法。分享给大家供大家参考。具体如下:using System;using System.IO;u
- 什么是栈和队列栈如果用数组模拟的话是类似于一个U形桶状堆栈空间,地下是封口的,只能从顶部一个地方进出,它的进出都是有顺序的,看下图:如果是进
- 1.在C#中使用FolderBrowserDialog类,就可以实现选择文件夹的功能,并将所选择的的文件夹路径记录下来。(1).首先先引入命
- 本文实例介绍了手机号码归属地接口调用基于C#实现,分享给大家供大家参考,具体内容如下using System;using System.Co
- 环境操作系统windows10JDKjdk1.8.0_192IDEEclipse IDE for Enterprise Java Devel
- 前言我们在 页面切换转场动画,英雄救场更有趣!介绍了 Hero 动画效果,使用 Hero 用于转场能够提供非常不错的体验。既然称之
- 本文实例为大家分享了unity实现场景切换进度条显示的具体代码,供大家参考,具体内容如下一、UI。建立slider适当更改即可;二、新增lo
- 本文实例讲述了C#生成单页静态页简单实现方法。分享给大家供大家参考。具体方法如下:protected void BtGroup_Server
- 我就废话不多说了,大家还是直接看代码吧~<!-- 查询物品的id --><select id="checkIte
- 通过下面一张图看下要实现的功能,具体详情如下所示:现在我就来介绍些软件的其它功能。希望大家有所受益。模拟人为搜索商品在刷单的时候,不能直接拿
- jasperreport导出的pdf每页显示的记录太少主要是确保Details的高度与Details中Field Text的高度一致。jas
- Spring容器可以自动装配相互协作bean之间的关系,这有助于减少对XML配置,而无需编写一个大的基于Spring应用程序的较多的<
- 相同:1、LinkedBlockingQueue和ArrayBlockingQueue都实现了BlockingQueue接口;2、Linke
- 一. SpringBoot集成liquibase项目集成liquibase作用对数据库表字段进行版本控制项目初始化部署时初始化数据库表和数据