springboot 配置使用swagger2操作
swagger是一個(gè)功能強(qiáng)大的在線API文檔的框架,提供了優(yōu)雅的API在線文檔的查閱和測(cè)試功能。
利用swagger2可以很方便的構(gòu)建RESTful風(fēng)格的API文檔,在springboot中使用也非常方便,主要是在controller前配置添加注解就可以了,詳細(xì)配置過程如下:
1. maven依賴包
使用目前最新版本為例,pom.xml添加的代碼如下
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.9.2</version> </dependency> <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.9.2</version> </dependency>
2. 配置類的編寫
配置類的編寫同樣非常簡(jiǎn)單,可以直接復(fù)制粘貼以下代碼,但是一定要注意做適當(dāng)修改,尤其是設(shè)置basePackage的路徑,一定要根據(jù)實(shí)際情況修改。
新建一個(gè)config文件夾,在此文件夾中新建一個(gè)類
package cn.smileyan.swagger.config;import org.springframework.beans.factory.annotation.Configurable;import org.springframework.context.annotation.Bean;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;@EnableSwagger2@Configurablepublic class Swagger2 { /** * 特別要注意.apis(RequestHandlerSelectors.basePackage('cn.smileyan.swagger.controller')) * 此中的cn.smileyan.swagger.controller一定要修改為自己controller包。 * @return */ @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.basePackage('cn.smileyan.swagger.controller')).paths(PathSelectors.any()).build(); } private ApiInfo apiInfo() { return new ApiInfoBuilder().title('springboot使用swagger例子').description('簡(jiǎn)單優(yōu)雅的restful風(fēng)格').termsOfServiceUrl('https://smileyan.cn').version('1.0').build(); }}
不能忘記類前面的@EnableSwagger2 與 @Configurable配置注解。以及后面的@Bean注解。
3. @EnableSwagger2 不能忘了
除了這個(gè)位置需要添加這個(gè)注解,還有springboot的運(yùn)行類(application類)也要添加這個(gè)注釋,否則會(huì)出現(xiàn)錯(cuò)誤。
如圖所示,我的application類名為SwaggerApplication,在這個(gè)類上面添加@EnableSwagger2
package cn.smileyan.swagger;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import springfox.documentation.swagger2.annotations.EnableSwagger2;@SpringBootApplication@EnableSwagger2public class SwaggerApplication { public static void main(String[] args) { SpringApplication.run(SwaggerApplication.class, args); }}
4. 編寫controller類,添加注解,注意這個(gè)controller路徑與上面配置類的路徑要保持一致。
package cn.smileyan.swagger.controller;import io.swagger.annotations.ApiOperation;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.RestController;import java.util.HashMap;import java.util.Map;@RestController@RequestMapping('/user')public class UserController { @ApiOperation(value = '用戶測(cè)試',notes = '貴賓用戶') @RequestMapping(value = '',method = RequestMethod.GET) private Map<String,String> getUser() { Map<String,String> map = new HashMap<>(1); map.put('result','success'); return map; }}
5. 運(yùn)行,打開api文檔http://localhost:8080/swagger-ui.html
效果如下:

可以點(diǎn)開user-controller,效果如下:

完成測(cè)試。很簡(jiǎn)單吧。
常用注解
@Api : 修飾整個(gè)類,用于描述Controller類
@ApiOperation:描述類的方法,或者說一個(gè)接口
@ApiParam:?jiǎn)蝹€(gè)參數(shù)描述
@ApiModel:用對(duì)象來接收參數(shù)
@ApiProperty:用對(duì)象接收參數(shù)時(shí),描述對(duì)象的一個(gè)字段
@ApiResponse:HTTP響應(yīng)的一個(gè)描述
@ApiResponses:HTTP響應(yīng)的整體描述
@ApiIgnore:使用該注解,表示Swagger2忽略這個(gè)API
@ApiError:發(fā)生錯(cuò)誤返回的信息
@ApiParamImplicit:一個(gè)請(qǐng)求參數(shù)
@ApiParamsImplicit:多個(gè)請(qǐng)求參數(shù)
以上這篇springboot 配置使用swagger2操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. IntelliJ IDEA設(shè)置自動(dòng)提示功能快捷鍵的方法2. 通過Django Admin+HttpRunner1.5.6實(shí)現(xiàn)簡(jiǎn)易接口測(cè)試平臺(tái)3. Docker 部署 Prometheus的安裝詳細(xì)教程4. IntelliJ IDEA安裝插件的方法步驟5. idea重置默認(rèn)配置的方法步驟6. idea導(dǎo)入maven項(xiàng)目的方法7. php過濾器使用詳解8. idea給項(xiàng)目打war包的方法步驟9. idea打開多個(gè)窗口的操作方法10. IntelliJ IDEA調(diào)整字體大小的方法

網(wǎng)公網(wǎng)安備