中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot?Knife4j在線API文檔框架怎么使用

發布時間:2022-12-09 09:22:15 來源:億速云 閱讀:143 作者:iii 欄目:開發技術

本篇內容主要講解“SpringBoot Knife4j在線API文檔框架怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“SpringBoot Knife4j在線API文檔框架怎么使用”吧!

1.Knife4j在線API文檔基本使用

Knife4j是一款基于Swagger 2的在線API文檔框架。

使用Knife4j的基礎步驟:

  • 添加依賴

  • application.properties/application.yml中添加配置

  • 在項目中添加配置類

關于依賴項:

<!-- Knife4j Spring Boot:在線API -->
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-spring-boot-starter</artifactId>
    <version>2.0.9</version>
</dependency>

注意:以上依賴項的版本是2.0.9,適用于Spring Boot 2.6以下(不含2.6)版本。

關于配置文件中的配置,主要是開啟此框架的增強模式(Knife4j定義的概念),需要添加:

knife4j.enable=true

關于配置類:

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();
    }
}

注意:務必檢查以上配置類中的basePackage屬性的值,必須是當前項目中控制器類所在的包!

在項目中已經完成以上步驟后,啟動項目,打開瀏覽器,通過http://localhost:8080/doc.html即可訪問在線API文檔。

2.配置API文檔信息

@Api:添加在控制器類上

  • 此注解的tags屬性,可配置模塊名稱,可以在模塊名稱中使用編號,例如:01. 品牌管理模塊,最終將按照編號升序排列

@ApiOperation:添加在控制器類中處理請求的方法上

  • 此注解的value屬性,可配置業務名稱

@ApiOperationSupport:添加在控制器類中處理請求的方法上

  • 此注解的order屬性(int類型),可配置業務的排序序號,最終將升序排列

@ApiModelProperty:添加在POJO類型的屬性上

  • 此注解的value屬性,可配置參數名稱(說明)

  • 此注解的required屬性,可配置是否必須提交此參數

  • 此注解的example屬性,可配置此請求參數的示例值

@ApiImplicitParam:添加在控制器類中處理請求的方法上,用于對未封裝的請求參數添加說明(例如Long id參數)

  • 必須配置此注解的name屬性,取值為方法的參數名稱,表示當前注解對哪個參數進行說明

  • 此注解的value屬性,可配置參數名稱(說明)

  • 此注解的required屬性,可配置是否必須提交此參數

  • 此注解的dataType屬性,可配置參數的數據類型(例如取值為"long"

  • 此注解的example屬性,可配置此請求參數的示例值

@ApiImplicitParams:添加在控制器類中處理請求的方法上,此注解的value屬性是@ApiImplicitParam注解的數組類型,當需要使用@ApiImplicitParam對多個未封裝參數進行說明時,需要將多個@ApiImplicitParam注解的配置作為當前注解的參數

@ApiOperation("刪除類別")
@ApiOperationSupport(order = 200)
@ApiImplicitParams({
    @ApiImplicitParam(name = "id", value = "類別ID", required = true, dataType = "long"),
    @ApiImplicitParam(name = "userId", value = "用戶ID", required = true, dataType = "long")
})
@PostMapping("/delete")
public void delete(Long userId, Long id) {}

到此,相信大家對“SpringBoot Knife4j在線API文檔框架怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

济南市| 齐齐哈尔市| 建昌县| 文山县| 尼玛县| 修文县| 阳江市| 永康市| 恭城| 鄢陵县| 尤溪县| 五原县| 克拉玛依市| 安图县| 黔东| 临颍县| 铜川市| 汶上县| 沙坪坝区| 浦江县| 汝南县| 双柏县| 永年县| 定南县| 凭祥市| 新兴县| 鲁山县| 揭东县| 周宁县| 福建省| 兴国县| 淳安县| 扎赉特旗| 库伦旗| 吉隆县| 屏东市| 安岳县| 绩溪县| 香河县| 临高县| 平潭县|