您好,登錄后才能下訂單哦!
本篇內容主要講解“SpringBoot Knife4j在線API文檔框架怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“SpringBoot 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文檔。
@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文檔框架怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。