




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第springboot集成Swagger的方法(让你拥有属于自己的api管理器)很多朋友问小编springboot项目中怎么集成Swagger呢?
swagger世界上最好的api管理工具
我们为什么要使用api管理工具?在大型的项目中,如果你有非常多的接口需要统一管理,或者需要进行接口测试,那么我们通常会在繁杂地api中找到需要进行测试或者管理的接口。当然,我们可以使用postman或者谷歌浏览器自带的apiTalendapiTester。但是这些工具往往只是对单个接口进行测试管理,是我们主动去人为管理的,那么为了减轻管理测试的人力成本,swagger便应运而生。
一、swagger是什么?
我先通过官方的解释去给各位读者描述:Swagger的目标是为RESTAPIs定义一个标准的,与语言无关的接口,使人和计算机在看不到源码或者看不到文档或者不能通过网络流量检测的情况下能发现和理解各种服务的功能。当服务通过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}=awaitthis.$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.1maven引入依赖
代码如下(示例):
SpringBoot集成Swagger=springfox,两个jar包
Springfox-swagger2
swagger-springmvc
使用Swagger
要求:jdk1.8+否则swagger2无法运行
步骤:
1、新建一个SpringBoot-web项目
2、添加Maven依赖
在pom.xml中引入依赖:
!--/artifact/io.springfox/springfox-swagger2--
dependency
groupIdio.springfox/groupId
artifactIdspringfox-swagger2/artifactId
version2.9.2/version
/dependency
!--/artifact/io.springfox/springfox-swagger-ui--
dependency
groupIdio.springfox/groupId
artifactIdspringfox-swagger-ui/artifactId
version2.9.2/version
/dependency
2.2编写Controller层,测试确保运行成功
代码如下(示例):要保证swagger有可以生成的api.
2.3在Utils工具包中引入swagger配置
要使用Swagger,我们需要编写一个配置类-SwaggerConfig来配置Swagger
@Configuration//配置类
@EnableSwagger2//开启Swagger2的自动配置
publicclassSwaggerConfig{
运行springboot项目,访问本地:http://localhost:8080/swagger-ui.html
这里我们基本上是可以使用了,但是很多配置都是默认的,所以我们要进一步配置
2.4swagger的详细配置
我自己放我的配置,拿来即用!我已经写好注释!
packagecom.naughty.userlogin02.util;
importorg.omg.CORBA.Environment;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
importorg.springframework.core.env.Profiles;
importspringfox.documentation.builders.PathSelectors;
importspringfox.documentation.builders.RequestHandlerSelectors;
importspringfox.documentation.service.ApiInfo;
importspringfox.documentation.service.Contact;
importspringfox.documentation.spi.DocumentationType;
importspringfox.documentation.spring.web.plugins.Docket;
importspringfox.documentation.swagger2.annotations.EnableSwagger2;
importjava.util.ArrayList;
@Configuration//配置类
@EnableSwagger2//开启Swagger2的自动配置
publicclassSwaggerConfig{
@Bean
publicDocketdocket(){
//设置要显示swagger的环境
//通过enable()接收此参数判断是否要显示
returnnewDocket(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();
//配置文档信息
privateApiInfoapiInfo(){
Contactcontact=newContact("沉默这忍受","/ILOVEMYDEAR","hjj2857154359@126.com");
returnnewApiInfo(
"Cartest",//标题
"索引测试管理api",//描述
"v1.0",//版本
"/ILOVEMYDEAR",//组织链接
contact,//
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 敬老院五保户合同协议书
- 木工承包合同协议书
- 物流公司劳务合同协议书
- 离职协议合同协议书
- 松树的承包合同协议书
- 艺术培训服务合同协议书
- 贷款合同协议书
- 爆破合同协议书范本
- 场地项目经理合同协议书
- 地板打蜡合同协议书范本
- 北大A计划在线测评题
- 微博运营方案及工作计划
- 《体育精神》-体育故事与体育精神培养教案
- 部编本一年级下册1、吃水不忘挖井人名师公开课获奖课件百校联赛一等奖课件
- 投资合同:有限公司投资协议
- 四川大学华西口腔医院临床研究医学伦理审查申请表【模板】
- 拖欠房租通知书范文
- 年产万吨的氯乙烯合成工段的工艺设计
- 2024年湖北省中考历史试卷附答案
- 2024年银行校园招聘入职考试模拟试题及答案(共三套)
- 2024年新疆乌鲁木齐市中考化学适应性试卷
评论
0/150
提交评论