Swagger接口文档 —— 手把手教学,全方位超详细小白能看懂,百分百能用Java版

本文主要是介绍Swagger接口文档 —— 手把手教学,全方位超详细小白能看懂,百分百能用Java版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🧸欢迎来到dream_ready的博客,📜相信您对博主首页也很感兴趣o (ˉ▽ˉ;)

博主首页,更多redis、java等优质好文以及各种保姆级教程等您挖掘!

目录

一、介绍

二、导入依赖

三、在配置类中加入 knife4j 相关配置

四、设置静态资源映射

五、注意放开拦截器拦截 

六、使用方式

常用注解

标记数据 

Controller

Model 

七、查看演示效果

八、设置全局都穿的参数 —— 例如token


一、介绍

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

官网:https://swagger.io/

Knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案。

二、导入依赖

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

此处导入的是Knife4j,这是一个为MVC框架集成Swagger生成文档的解决方案 

三、在配置类中加入 knife4j 相关配置

亲爱的朋友,希望你不要告诉我你不会写配置类,不会配置类的话看文末最下面有最基础的配置类的教程,保证你能用上最好用的Swagger文档

是在配置类中添加下面内容哦

注意修改里面的一些内容,比如汉字部分以及那个扫描包的路径

    /*** 通过knife4j生成接口文档* @return*/@Beanpublic Docket docket1() {log.info("准备生成接口文档...");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.example.cvresume.controller")).paths(PathSelectors.any()).build();return docket;}

这个扫描包的路径切记要修改哦 

需要注意的是,这个方法可以设置多个,来使接口文档分页,只要方法名不重复即可

四、设置静态资源映射

设置静态资源映射,否则接口文档页面无法访问

也是在配置类中书写哦

下面这个基本是固定的,不用改,若你想玩一下Swagger的更多玩法,那么你可以去查阅官方文档

    /*** 设置静态资源映射* @param registry*/protected void addResourceHandlers(ResourceHandlerRegistry registry) {log.info("开始设置静态资源映射...");registry.addResourceHandler("/doc.html").addResourceLocations("classpath:/META-INF/resources/");registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");}

五、注意放开拦截器拦截 

要注意拦截器拦截,比如如果你设置的有JWT校验,那么就要在配置拦截器那里放开下面这几个静态资源

"/swagger-resources/**", "/doc.html", "/webjars/**", "/v2/**", "/swagger-ui.html/**"

类似我这样写:

六、使用方式

其实你已经可以使用了,来进入这个页面看一下吧

当你在写配置的时候,需要指定一个扫描路径,它就会自动扫描所有接口,获取对应的数据,构建接口文档

浏览器输入下面这个地址

注意修改ip和端口号为你正在使用的,其他不变

http://127.0.0.1:8080/doc.html

只不过你会发现它没有备注,当你遇到很麻烦的数据的时候,根本不知道每个属性是干嘛的,这时候就需要使用注解了 

利用注解标记Controller和Model层对应的数据,然后利用这些标记的数据自动生成接口文档中对应数据的备注 

常用注解

通过注解可以控制生成的接口文档,使接口文档拥有更好的可读性,常用注解如下:

标记数据 

现在我对我的login接口进行改造,使其出现在接口文档上

我这里将原来和标记后的代码都进行了展示,主要是看注解,不要看我的逻辑代码,此篇博客只是为了让大家真正上手Swagger的使用

Controller

原来的:

标记后:

可以看到我用@Api标记了UserCroller这个类,用@ApiOperation标记了login这个方法

Model 

其实基本项目中的所有Model都要做标记,因为不一定啥时候用到,Model做标记的主要原因是让Swagger知道传来了什么参数(传对象时),或返回了什么参数

原来的:

@Data
public class User {private Integer id;private String username; // 用户名private String password; // 密码private String nickname; // 昵称private String avatarPath; // 头像路径private String sex; // 性别private String phone; // 电话private Integer role; // 角色private String hospital; // 医院名称private LocalDateTime createTime;private LocalDateTime updateTime;
}

标记后:

可以看到,我利用了@ApiModel标记实体类,用@ApiModelProperty标记属性

@Data
@ApiModel(description = "用户信息")
public class User {@ApiModelProperty(value = "用户ID")private Integer id;@ApiModelProperty(value = "用户名")private String username;@ApiModelProperty(value = "密码")private String password;@ApiModelProperty(value = "昵称")private String nickname;@ApiModelProperty(value = "头像路径")private String avatarPath;@ApiModelProperty(value = "性别")private String sex;@ApiModelProperty(value = "电话")private String phone;@ApiModelProperty(value = "角色")private Integer role;@ApiModelProperty(value = "医院名称")private String hospital;@ApiModelProperty(value = "创建时间")private LocalDateTime createTime;@ApiModelProperty(value = "更新时间")private LocalDateTime updateTime;
}

然后因为我这个项目有一个统一返回的对象Result,所以我对Result也要用注解加个标记

原来的:

标记后:

七、查看演示效果

咱们来发送个请求:

点击调试,可以看到,需要传的参数直接给我们了,多么的方便呀

当时,参数值需要我们填哈哈

来我们再看一个,哪怕传来的是对象,他也应对自如

点击调试,我们只需要填写参数值即可

若你想全部都加上备注,就需要辛苦一下啦

说一个小窍门,丢给GPT,然后修改一下即可哈哈哈

八、设置全局都穿传的参数 —— 例如token

例如我这里

手动先发送个请求,获取登陆后的token

将token添加到“全局参数设置”这里

点击添加参数

这个时候你再发送任何请求,都会自动带上这个全局参数了

教程至此结束,这篇教程更适用于新手,Swagger进阶等我有空了会补充,但这篇博客足以满足大部分学习者了

🧸前路漫漫,愿星光与您相伴!

这篇关于Swagger接口文档 —— 手把手教学,全方位超详细小白能看懂,百分百能用Java版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/916415

相关文章

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.