[SpringBoot]Knife4j框架Knife4j的显示内容的配置

news2025/1/9 1:48:07

目录

Knife4j框架

使用 

添加依赖:knife4j-spring-boot-starter,版本2.0.9

添加配置:在配置文件中添加knife4j.enable属性的配置,取值为true

添加配置类:类的代码相对固定

 访问

Knife4j的显示内容的配置


 

Knife4j框架

Knife4j框架是一款国人开发的、基于Swagger 2的在线API文档框架。  

Knife4j框架的一些主要作用和特点:

  1. 自动生成API文档:Knife4j可以根据代码中的注解和配置信息,自动生成API接口文档。开发者只需要在代码中添加相关注解,就能够生成详细的API文档,包括接口描述、请求参数、响应结果等信息。

  2. 接口文档展示:Knife4j生成的API文档以用户友好的方式展示,包括接口列表、接口详情、请求示例、参数说明等。开发者可以通过浏览器访问API文档,方便查阅和理解接口的使用方式。

  3. 接口测试工具:Knife4j提供了接口测试工具,可以直接在文档界面进行接口测试,无需额外的接口测试工具。开发者可以通过输入参数、发送请求,并查看响应结果,方便调试和验证接口的正确性。

  4. 接口权限控制:Knife4j支持对API接口进行权限控制,可以配置接口的访问权限,限制某些接口只能被特定的角色或用户访问。

  5. 接口在线调试:Knife4j提供了在线调试功能,可以在文档界面直接发送请求并查看响应结果,方便开发者进行接口的调试和验证。

使用 

 Knife4j的简单使用只需要3步:

添加依赖:knife4j-spring-boot-starter,版本2.0.9

  • 注意:建议使用Spring Boot 2.5.x版本,如果使用更高版的Spring Boot,Knife4j的版本也需要提高

<knife4j-spring-boot.version>2.0.9</knife4j-spring-boot.version>
<!-- Knife4j Spring Boot:在线API文档 -->
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-spring-boot-starter</artifactId>
    <version>${knife4j-spring-boot.version}</version>
</dependency>

添加配置:在配置文件中添加knife4j.enable属性的配置,取值为true

添加配置类:类的代码相对固定

检查配置Controller包的属性值是否与你的项目相符合  

 

package cn.tedu.csmall.product.config;

import com.github.xiaoymin.knife4j.spring.extension.OpenApiExtensionResolver;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
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;

/**
 * Knife4j配置类
 *
 * @author java@tedu.cn
 * @version 0.0.1
 */
@Slf4j
@Configuration
@EnableSwagger2WebMvc
public class Knife4jConfiguration {

    /**
     * 【重要】指定Controller包路径
     */
    private String basePackage = "cn.tedu.csmall.product.controller";
    /**
     * 分组名称
     */
    private String groupName = "product";
    /**
     * 主机名
     */
    private String host = "http://java.tedu.cn";
    /**
     * 标题
     */
    private String title = "酷鲨商城在线API文档--商品管理";
    /**
     * 简介
     */
    private String description = "酷鲨商城在线API文档--商品管理";
    /**
     * 服务条款URL
     */
    private String termsOfServiceUrl = "http://www.apache.org/licenses/LICENSE-2.0";
    /**
     * 联系人
     */
    private String contactName = "Java教学研发部";
    /**
     * 联系网址
     */
    private String contactUrl = "http://java.tedu.cn";
    /**
     * 联系邮箱
     */
    private String contactEmail = "java@tedu.cn";
    /**
     * 版本号
     */
    private String version = "1.0.0";

    @Autowired
    private OpenApiExtensionResolver openApiExtensionResolver;

    public Knife4jConfiguration() {
        log.debug("创建配置类对象:Knife4jConfiguration");
    }

    @Bean
    public Docket docket() {
        String groupName = "1.0.0";
        Docket docket = new Docket(DocumentationType.SWAGGER_2)
                .host(host)
                .apiInfo(apiInfo())
                .groupName(groupName)
                .select()
                .apis(RequestHandlerSelectors.basePackage(basePackage))
                .paths(PathSelectors.any())
                .build()
                .extensions(openApiExtensionResolver.buildExtensions(groupName));
        return docket;
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title(title)
                .description(description)
                .termsOfServiceUrl(termsOfServiceUrl)
                .contact(new Contact(contactName, contactUrl, contactEmail))
                .version(version)
                .build();
    }
}

完成后,可以通过 /doc.html 来访问API文档,即在浏览器的地址栏中输入网址:http://localhost:8080/doc.html

 访问


Knife4j的显示内容的配置

 @Api:添加在控制器类上,通过此注解的tags属性,可以配置模块名称(显示在API文档左侧目录中的名称),提示:当存在多个控制器时,显示的顺序是根据配置的模块名称来决定的,如果需要自行指定顺序,建议在各模块名称前添加数字编号,例如:

@RestController
@RequestMapping("/album")
@Api(tags = "04. 相册管理模块")
public class AlbumController {
}
  • @ApiOperation:添加在处理请求的方法上,通过此注解的value属性,可以配置业务功能名称

  • @ApiOperationSupport:添加在处理请求的方法上,通过此注解的order属性(int类型),可以配置业务功能的排序序号,将升序排列,例如:

@PostMapping("/delete")
@ApiOperation("根据ID删除相册")
@ApiOperationSupport(order = 200)
public String delete() {
    // ...
}

 @ApiModelProperty:添加在封装的请求参数的属性上,通过此注解的value属性,可以配置请求参数的描述信息,通过此注解的required属性,可以配置是否必须提交此参数(此配置只是一种显示效果,并不具备真正的检查功能),通过此注解的example属性,可以配置示例值,(示例值不是说明是举例,要满足属性类型,如果在排序Integer 输入字符串会报错)例如:

@Data
public class AlbumAddNewParam implements Serializable {

    @ApiModelProperty(value = "相册名称", required = true, example = "可乐的相册")
    private String name;

    @ApiModelProperty(value = "相册简介", required = true, example = "可乐的相册的简介")
    private String description;

    @ApiModelProperty(value = "排序序号,必须是1~255之间的数字", required = true, example = "97")
    private Integer sort;

}

 @ApiIgnore:添加在请求参数上,表示API文档将忽略此请求参数

@PostMapping("/add-new")
@ApiOperation("添加相册")
@ApiOperationSupport(order = 100)
public String addNew(AlbumAddNewParam albumAddNewParam, 
                     @ApiIgnore HttpSession session) {
    // ...
}
  • @ApiImplicitParam:添加在处理请求的方法上,用于对未封装的请求参数进行描述,注意,此注解必须配置name属性,取值为方法的参数名,然后,结合此注解的value属性对参数进行描述,此注解还有与@ApiModelProperty相同的一些属性,例如requiredexample等,还可以通过dataType指定数据类型
  • @ApiImplicitParams:添加在处理请求的方法上,当有多个@ApiImplictParam需要被配置时,应该将它们作为当前@ApiImplicitParams的属性值,例如:
@PostMapping("/delete")
@ApiOperation("根据ID删除相册")
@ApiOperationSupport(order = 200)
@ApiImplicitParams({
        @ApiImplicitParam(name = "albumId", value = "相册ID", required = true, dataType = "long"),
        @ApiImplicitParam(name = "userId", value = "用户ID", required = true, dataType = "long")
})
public String delete(Long albumId, Long userId) {
    // ...
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/602633.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

赶紧收藏!2023年成人高考【复习大纲】

▶高起点考试题型 高起点-语文 试卷满分为150分。考试用时120分钟。 >>>考试内容&#xff1a; 语言知识及运用、现代文阅读、古代诗文阅读和鉴赏、写作四个方面&#xff0c;考试以测试阅读和写作能力为重点。 >>>备考分析&#xff1a; 语文学习要注意平…

【Python】实现一个类似于Thief的摸鱼软件

一 背景说明 之前用Thief摸鱼(Thief官网&#xff09;&#xff0c;觉得挺好用。对于其最基本的TXT摸鱼&#xff0c;准备在Python中扩展一下功能&#xff0c;使其能够通过爬虫&#xff0c;支持爬取热门小说网站的内容。 软件已经开源到&#xff1a;MoFish软件开源地址 功能是&…

ReID专栏(一) 任务与数据集概述

前言 本专栏针对Closed-world的ReID任务&#xff0c;首先介绍本任务的目标与主要数据集&#xff0c;包括行人重识别、跨模态行人重识别与车辆重识别。然后从三类表征学习的角度解读相关论文&#xff0c;表征学习是本任务的核心&#xff0c;大量重识别工作都致力于提高表征学习的…

uboot源码结构、配置、编译

目录 1.uboot源码结构 1.1uboot源码获取 1.2 uboot的特点 1.3 uboot源码结构 2、uboot配置与编译 2.1uboot配置 2.2 uboot编译 1.uboot源码结构 1.1uboot源码获取 uboot是一个开源的软件。开源有两层含义。一是可以免费用、二是开放源代码 uboot源码下载 http://www.denx…

记一次线上MQ堆积问题处理

背景 线上订单服务10个POD节点&#xff0c;某kafka tpoic原有6个分区。 问题现象 上午11.30左右一波下单高峰&#xff0c;根据分布式消息告警发现有少量消息堆积&#xff0c;但是堆积量不大&#xff0c;持续几分钟后恢复正常。 下午1点后出现新一轮高峰&#xff0c;出现了大…

window环境安装kafka

一、配置系统环境变量 JAVA_HOME 二、配置安装zookeeper 1、下载安装包 https://zookeeper.apache.org/releases.html#download 2、 解压并进入ZooKeeper目录&#xff0c;如&#xff1a;D:\kafka\zookeeper\conf, 将“zoo_sample.cfg”重命名为“zoo.cfg”, 3、打开“zoo.c…

机器学习集成学习——GBDT(Gradient Boosting Decision Tree 梯度提升决策树)算法

系列文章目录 机器学习神经网络——Adaboost分离器算法 机器学习之SVM分类器介绍——核函数、SVM分类器的使用 机器学习的一些常见算法介绍【线性回归&#xff0c;岭回归&#xff0c;套索回归&#xff0c;弹性网络】 文章目录 系列文章目录 前言 一、GBDT(Gradient Boos…

PHP学习笔记第三天

前言 作者简介&#xff1a;不知名白帽&#xff0c;网络安全学习者。 博客主页&#xff1a;不知名白帽的博客_CSDN博客-网络安全,CTF,内网渗透领域博主 网络安全交流社区&#xff1a;https://bbs.csdn.net/forums/angluoanquan 目录 PHP if..else PHP switch PHP数组 PHP数…

【AI 孙燕姿 || AI 音色转换】RVC 使用图文教程:教你如何实现无难度男女换声(伪音)以及 AI 孙燕姿!

最近&#xff0c;视频网站音乐区up主掀了“AI孙燕姿”的风潮。这种使用AI技术提取某位歌手的音色&#xff0c;再用其替换另一位歌手音色的方式&#xff0c;可以实现接近歌手本人翻唱的逼真效果。除孙燕姿外&#xff0c;面对周杰伦、陶喆、陈奕迅、王菲等众多具有独特嗓音的歌手…

YOLOv3: An Incremental Improvement 全文翻译

YOLOv3 论文全篇完整翻译 摘要 本文介绍了YOLO的一些更新内容&#xff01;我们进行了一系列小的设计改进&#xff0c;以使其更好。我们还训练了一个相当不错的新网络。它比上一版稍微大一些&#xff0c;但更加准确。不过不用担心&#xff0c;它依然保持了快速性能。在320320像…

C++数据结构:图结构入门

C数据结构 线性顺序表&#xff08;数组&#xff09; 线性顺序表&#xff08;链表&#xff09; Python风格双向链表的实现 散列表简单实现&#xff08;hash表&#xff09; 栈和队列的应用 二叉树之一&#xff08;数组存储&#xff09; 二叉树之二&#xff08;二叉搜索树&#x…

驱动开发:内核PE结构VA与FOA转换

本章将继续探索内核中解析PE文件的相关内容&#xff0c;PE文件中FOA与VA,RVA之间的转换也是很重要的&#xff0c;所谓的FOA是文件中的地址&#xff0c;VA则是内存装入后的虚拟地址&#xff0c;RVA是内存基址与当前地址的相对偏移&#xff0c;本章还是需要用到《驱动开发&#x…

第二十篇、基于Arduino uno,获取MFRC-522 RFID射频IC卡模块的信息,并进行识别——结果导向

0、结果 说明&#xff1a;先来看看串口调试助手显示的结果&#xff0c;"卡号"对应的是IC卡的卡号&#xff0c;"1号已进入"表示识别到正确的卡&#xff0c;也就是之前录入的卡号&#xff0c;因此可以应用到门禁。如果是你想要的&#xff0c;可以接着往下看…

OLED和LCD对比

OLED和LCD对比 今天等离子已不复存在&#xff0c;OLED 出现了新的竞争者。在本概述中&#xff0c;我们将了解这两种技术之间的差异、优缺点等。 我们将从简短介绍每种显示技术的工作原理开始。我们将使用术语“面板”&#xff0c;因为显示技术是功能性电视屏幕的一个组成部分…

(字符串 ) 151. 反转字符串中的单词 ——【Leetcode每日一题】

❓151. 反转字符串中的单词 难度&#xff1a;中等 给你一个字符串 s &#xff0c;请你反转字符串中 单词 的顺序。 单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。 返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。 注意&…

面向对象编程 实验三 sduwh 子窗口与控件的基本用法、资源的使用 参考实验报告1

源自网络收集&#xff0c;仅供参考 实验三收集到两份完整报告&#xff0c;这是其一&#xff0c;另一份见本专栏下一篇文章。 实验题目 《面向对象程序设计》 实验三 实验题目&#xff1a;子窗口与控件的基本用法、资源的使用 整体目的&#xff1a;理解、窗口之间的消息传送…

DAY08_JavaScrip

目录 1 JavaScript1.1 JavaScript简介1.2 JavaScript引入方式1.2.1 内联脚本1.2.2 内部脚本1.2.3 外部脚本 1.3 JavaScript基础语法1.3.1 书写语法1.3.2 输出语句1.3.3 变量1.3.4 数据类型1.3.5 运算符1.3.5.1 \和区别1.3.5.2 类型转换 1.3.6 流程控制语句1.3.6.1 if 语句1.3.6…

常见设计模式

单例模式 单例对象的类必须保证只有一个实例存在&#xff0c;整个系统只能使用一个对象实例&#xff0c;优点&#xff1a;不会频繁地创建和销毁对象&#xff0c;浪费系统资源。缺点是没有抽象层&#xff0c;难以扩展。 单例模式的常见写法&#xff1a; 饿汉式单例模式的写法&…

免安装版MySQL数据库的安装和卸载

说明&#xff1a;MySQL早些版本有分安装版和免安装版&#xff0c;可在官网&#xff08;https://dev.mysql.com/downloads/mysql/&#xff09;下载&#xff0c;推荐使用最新版本&#xff0c;是免安装版的&#xff0c;下载完配置一下就可以用。 推荐使用最新版本 安装 我这里以…

第3章“程序的机器级表示”:过程

文章目录 3.7 过程3.7.1 栈帧3.7.2 转移控制3.7.3 寄存器使用惯例3.7.4 过程示例3.7.5 递归过程 3.7 过程 一个过程调用包括将数据&#xff08;以过程参数和返回值的形式&#xff09;和控制从代码的一部分传递到另一部分。另外&#xff0c;它还必须在进入时为过程的局部变量分…