SpringBoot项目整合Knife4j接口文档

server/2024/9/22 23:02:24/

文章目录

  • 什么是接口文档?
  • 谁用接口文档
  • 为什么需要接口文档
  • 怎么做接口文档
  • springboot如何整合knife4j?
    • 1.引入依赖
    • 2.在config目录下创建Knife4j配置依赖
    • 3.在appliacation.yml中进行配置
    • 4.启动Spring Boot工程,在浏览器中访问:http://localhost:后端端口号/doc.html

什么是接口文档?

写满接口信息的文档,每条接口包括:请求参数,响应参数,接口地址,接口名称,请求类型,请求格式,备注

谁用接口文档

后端or负责人来提供,后端和前端都要使用

为什么需要接口文档

1.有个书面内容(归档),便于大家参考和查阅,便于沉淀和维护
2.便于前端和后端开发对接,前后端联调的介质,后端->接口文档-<前端
3.好的接口文档支持在线测试,可以作为工具提高开发效率

怎么做接口文档

1.手写
2.自动化接口文档生成:Swagger,Postman,apifox,apipost,eolink
knife4j官网
https://doc.xiaominfo.com/

springboot如何整合knife4j?

1.引入依赖

<!--引入Knife4j的官方start包,Swagger2基于Springfox2.10.5项目-->
<dependency><groupId>com.github.xiaoymin</groupId><!--使用Swagger2--><artifactId>knife4j-spring-boot-starter</artifactId><version>2.0.9</version>
</dependency>

2.在config目录下创建Knife4j配置依赖

(注意要填写控制器所在包的位置)

java">package com.example.usercenterbackend.config; /*** @author Shier* @date 2023/02/02* 自定义 Swagger 接口文档的配置*/import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
import springfox.documentation.builders.ApiInfoBuilder;
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.EnableSwagger2WebMvc;/*** @author: 诨号无敌鸭* @date: 2022/11/20* @ClassName: yupao-backend01* @Description: 自定义 Swagger 接口文档的配置*/
@Configuration
@EnableSwagger2WebMvc //启用 Swagger2 在 Spring MVC 环境中的使用。
@Profile({"dev", "test"})   //仅在"dev"和"test"两个环境下生效,即只有在开发和测试环境下才会启用 Swagger 接口文档配置。
public class SwaggerConfig {@Bean(value = "defaultApi2")public Docket defaultApi2() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select()// 这里一定要标注你控制器的位置.apis(RequestHandlerSelectors.basePackage("com.example.usercenterbackend.controller")).paths(PathSelectors.any()).build();}/*** api 信息* @return*/private ApiInfo apiInfo() {return new ApiInfoBuilder().title("无敌鸭用户中心").description("无敌鸭用户中心接口文档").termsOfServiceUrl("https://github.com/Serendipityzhezi").contact(new Contact("诨号无敌鸭", "https://blog.csdn.net/m0_74870396?spm=1000.2115.3001.5343","1342558165@qq.com")).version("1.0").build();}
}

3.在appliacation.yml中进行配置

spring:mvc:pathmatch:matching-strategy: ant_path_matcher#路径匹配策略 profiles:active: dev#开发环境设置

4.启动Spring Boot工程,在浏览器中访问:http://localhost:后端端口号/doc.html

即可访问到接口文档页面


http://www.ppmy.cn/server/3304.html

相关文章

CentOS 7静默安装Oracle 11g(记一次最小化CentOS 7安装Oracle 11g的经历)

# [pdf在线免费转word文档](https://orcc.online/pdf) https://orcc.online/pdf 1.最小化安装CentOS 7后首先设置一下固定IP 可以先查询一下自己的网卡设备的名称&#xff0c;是ens33&#xff0c;所以网卡配置文件名称就是ifcfg-ens33&#xff08;前面的ifcfg-不用管&#xf…

【大数据与云计算】虚拟机安装Linux

前言&#xff1a;使用Linux系统对大数据学习必不可少&#xff0c;本文主要介绍虚拟机安装linux的流程 文章目录 一、 下载VMware二、下载Linux三、安装Linux 一、 下载VMware 官网链接 下载VMware-player&#xff0c;一直下一步安装即可。 二、下载Linux 点击链接直接下载&…

Xinstall:实现注册后自动绑定,提升用户体验

在移动互联网时代&#xff0c;App的注册与绑定流程对于用户体验至关重要。繁琐的注册步骤和手动绑定操作往往会让用户望而却步&#xff0c;导致用户流失。为了解决这一问题&#xff0c;Xinstall品牌推出了注册后自动绑定功能&#xff0c;极大提升了用户体验。 Xinstall的自动…

基于机器学习的人脸发型推荐算法研究与应用实现

1.摘要 本文主要研究内容是开发一种发型推荐系统&#xff0c;旨在识别用户的面部形状&#xff0c;并根据此形状推荐最适合的发型。首先&#xff0c;收集具有各种面部形状的用户照片&#xff0c;并标记它们的脸型&#xff0c;如长形、圆形、椭圆形、心形或方形。接着构建一个面部…

弹性盒子(display: flex)布局

以下文章都可以参考 CSS - 完美解决 flex 布局下&#xff0c;一行显示固定个数&#xff08;平均分布&#xff09;并且强制换行&#xff0c;超出后 “靠左“ 对其&#xff08;详细解决方案&#xff0c;适用于 Web、Vue、React 等任何前端项目&#xff09;_flex设置一行几个-CSD…

【TCP套接字编程,UDP套接字编程】

文章目录 TCP套接字编程Socket编程Socket 编程TCP套接字编程TCPsocket编程C/S socket 交互: TCP数据结构 sockaddr_in数据结构 hostent UDP套接字编程UDP Socket编程Client/server socket 交互: UDP TCP套接字编程 Socket编程 应用进程使用传输层提供的服务才能交换报文。实现…

Swift-24-集合对象

数组Array 数组是值的有序集合&#xff0c;任何值都可以在数组中出现多次。数组通常用于值的有序很重要或者很有用的场合&#xff0c;但是值的顺序是否有意义并不是先决条件。与Objective-C不同的是&#xff0c;Swift的Array类型可以持有任何类型的值&#xff08;对象和非对象…

【python脚本】课表信息生成 course_test(源代码)

在处理excel表格数据中编写的一个可以自动处理课表信息的脚本。 import os import openpyxl import re# 检查文件是否存在 file_name "course_info.xlsx" if os.path.exists(file_name):# 如果文件存在&#xff0c;先删除os.remove(file_name)# 创建一个新的 Excel…