溫馨提示×

溫馨提示×

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

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

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

發(fā)布時(shí)間:2022-12-09 09:22:15 來源:億速云 閱讀:137 作者:iii 欄目:開發(fā)技術(shù)

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

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

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

使用Knife4j的基礎(chǔ)步驟:

  • 添加依賴

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

  • 在項(xiàng)目中添加配置類

關(guān)于依賴項(xiàng):

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

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

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

knife4j.enable=true

關(guān)于配置類:

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";
    /**
     * 主機(jī)名
     */
    private String host = "http://java.tedu.cn";
    /**
     * 標(biāo)題
     */
    private String title = "商城在線API文檔--商品管理";
    /**
     * 簡介
     */
    private String description = "商城在線API文檔--商品管理";
    /**
     * 服務(wù)條款URL
     */
    private String termsOfServiceUrl = "http://www.apache.org/licenses/LICENSE-2.0";
    /**
     * 聯(lián)系人
     */
    private String contactName = "Java教學(xué)研發(fā)部";
    /**
     * 聯(lián)系網(wǎng)址
     */
    private String contactUrl = "http://java.tedu.cn";
    /**
     * 聯(lián)系郵箱
     */
    private String contactEmail = "java@tedu.cn";
    /**
     * 版本號
     */
    private String version = "1.0.0";
    @Autowired
    private OpenApiExtensionResolver openApiExtensionResolver;
    public Knife4jConfiguration() {
        log.debug("創(chuàng)建配置類對象: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();
    }
}

注意:務(wù)必檢查以上配置類中的basePackage屬性的值,必須是當(dāng)前項(xiàng)目中控制器類所在的包!

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

2.配置API文檔信息

@Api:添加在控制器類上

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

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

  • 此注解的value屬性,可配置業(yè)務(wù)名稱

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

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

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

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

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

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

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

  • 必須配置此注解的name屬性,取值為方法的參數(shù)名稱,表示當(dāng)前注解對哪個(gè)參數(shù)進(jìn)行說明

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

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

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

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

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

@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文檔框架怎么使用”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI