如何在maven專案或者gradle專案中搭建swagger-本地測試工具
如何在maven專案或者gradle專案中搭建swagger-本地測試工具
Swagger是當前最好用的Restful API文件生成的開源專案,通過swagger-spring專案,實現了與SpingMVC框架的無縫整合功能,方便生成spring restful風格的介面文件, 同時swagger-ui還可以測試spring restful風格的介面功能。
1.在pom.xml中引入依賴
<!--Swagger本地測試介面工具 Swagger2核心包 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.7.0</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.7.0</version>
</dependency>
如果是 gradle 專案則在 build.gradle檔案 中新增以下依賴 (maven 無視這一條)
dependencies {
// 配置swagger
compile group: 'io.springfox', name: 'springfox-swagger2', version: '2.9.2'
compile group: 'io.springfox', name: 'springfox-swagger-ui', version: '2.9.2'
}
2.增加一個配置類
package org.sang.config;
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.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
/**
* @Author: XiaoPan
* @CreateTime: 2020-10-20 21:26
* Swagger 配置類
*/
@Configuration
@EnableSwagger2
public class SwaggerConfiguration {
@Bean
public Docket createRestApi(){
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com.cy.Controler"))
.paths(PathSelectors.any())
.build();
}
private ApiInfo apiInfo(){
return new ApiInfoBuilder()
.title("Spring Boot中使用Swagger2構建RESTful APIs")
.description("更多請關注http://www.baidu.com")
.termsOfServiceUrl("http://www.baidu.com")
.version("1.0")
.licenseUrl("http://localhost:8091/")
.build();
}
}
3.最後在Controler層的所有介面中加上@ApiOperation註解即可
Swagger預設訪問地址:http://localhost:8080/swagger-ui.html#/
介面說明:
@Api:用在請求的類上,表示對類的說明
tags = “說明該類的作用,可以在UI介面上看到的註解”
value = “該引數沒什麼意義,在UI介面上也看到,所以不需要配置”
@ApiOperation 是用在方法上面的,又來說明介面
value = “介面說明”
httpMethod = “介面請求方式”
response = “介面返回引數型別”
notes = “介面釋出說明”
@ApiImplicitParams 用在方法上,用來給此方法一組引數的說明規定
單個引數用@ApiImplicitParam
多個就用@ApiImplicitParams({@ApiImplicitParam(xxxxxxxxxxxxxxx),@ApiImplicitParam(xxxxxxxxxxxxxxx),xxxxx}) 陣列集
paramType = “指定引數放何處” 值有以下幾種:
header :請求引數放置於request header,使用@RequestHeader獲取
query:請求引數放置於地址中,使用@RequestParam獲取
path:這個結合restful風格使用時,用@PathVariable獲取
body:用@RequestBody獲取
form:不常用
@ApiParam註解屬性以及說明
required = “是否必須引數”
name = “引數名稱”
value = “引數具體描述”
@ApiResponses:用在請求的方法上,表示一組響應
@ApiResponse:用在@ApiResponses中,一般用於表達一個錯誤的響應資訊
code:數字,例如400
message:資訊,例如"請求引數沒填好"
response:丟擲異常的類
@ApiIgnore()用於類,方法,方法參數列示這個方法或者類被忽略
相關文章
- maven 專案轉化成 gradle 專案實踐MavenGradle
- 專案構建工具 GradleGradle
- 使用gradle搭建spring boot專案GradleSpring Boot
- Maven 專案引入本地 jar 包方法MavenJAR
- IDEA搭建和部署Maven專案IdeaMaven
- 如何在 Go 專案內寫測試Go
- 如何在github上傳本地專案Github
- idea ssm maven專案搭建筆記IdeaSSMMaven筆記
- SpringBoot + maven 父子模組專案搭建Spring BootMaven
- 如何在 Composer 專案中管理本地的 Git 鉤子?Git
- 專案實戰之gradle在實際專案中的使用Gradle
- 在gradle中構建java專案GradleJava
- Jmeter測試工具的實際專案測試案例JMeter
- Maven中POM專案物件模型Maven物件模型
- 在spring boot專案(maven)中引入其他 spring boot專案Spring BootMaven
- Maven 專案文件Maven
- Maven 專案模板Maven
- 如何在現有的Vue專案中嵌入 Blazor專案?VueBlazor
- 【Java】【專案構建】Idea中設定Gradle/Maven多模組依賴JavaIdeaGradleMaven
- Gradle實戰及Maven專案遷移採坑記錄GradleMaven
- 使用git工具上傳本地專案Git
- 測試生存指南!如何在快速迭代的專案中減少返工?
- FM專案如何本地聯調其他測試環境
- Gradle之多專案構建Gradle
- idea gradle 專案依賴IdeaGradle
- 使用IDEA建立gradle專案IdeaGradle
- Gradle構建SpringBoot專案GradleSpring Boot
- Eclipse中專案Maven相關配置EclipseMaven
- Maven專案中resources配置總結Maven
- IDEA設定預設Maven(使用idea maven archetype建立專案時,專案建立慢或者不完整,缺失部分目錄)IdeaMaven
- .NET 專案中的單元測試
- 初試Docker 搭建SpringBoot 專案DockerSpring Boot
- 效能測試專案篇
- iwebshop專案測試(一)Web
- MyEclipse2017破解設定與maven專案搭建EclipseMaven
- Eclipse-用Eclipse搭建一個maven專案-續EclipseMaven
- 【小白第一篇】maven搭建ssm專案MavenSSM
- ubuntu18.04上搭建django專案測試環境UbuntuDjango