使用Swagger自動生成API文檔,不只增長了項目的可維護性,還提升了API的透明度更利於快速測試等工做,便於更快地發現和解決問題。html
本篇文章只記錄整合過程,關於Security Configuration等其餘特性這裏就不展開講了,感興趣的能夠經過如下連接瞭解更多。java
參考文檔:web
https://howtodoinjava.com/swagger2/swagger-spring-mvc-rest-example/ http://www.baeldung.com/swagger-2-documentation-for-spring-rest-api http://blog.didispace.com/springbootswagger2/
項目中各組件的版本狀況:spring
spring.version=4.3.18.RELEASE jackson.version=2.9.0 swagger.version=2.7.0
核心的pom配置(spring的省略):apache
<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>${swagger.version}</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>${swagger.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>${jackson.version}</version> </dependency>
編寫Swagger的配置類:api
tip:作了攔截處理的同窗須要注意開放swagger的資源訪問路徑:/swagger-resources/*、/swagger-ui.html、/v2/api-docs、/webjars/*spring-mvc
@Configuration @EnableSwagger2 @EnableWebMvc @ComponentScan("springfox") public class SwaggerConfig extends WebMvcConfigurerAdapter { @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.withClassAnnotation(Api.class)) .paths(PathSelectors.any()) .build() .apiInfo(apiInfo()); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("REST API 描述文檔") .description("REST API 描述文檔") .version("1.0") .termsOfServiceUrl("http://localhost:9080/") .contact(new Contact("lichmama", "", "")) .license("Apache License 2.0") .licenseUrl("https://www.apache.org/licenses/LICENSE-2.0") .build(); } @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("swagger-ui.html").addResourceLocations("classpath:/META-INF/resources/"); registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/"); } }
在springmvc-servlet.xml中增長配置:springboot
<bean class="com.lichmama.demo.core.swagger.SwaggerConfig" />
在RestController上使用Swagger的註解(其中ApiOperation和ApiImplicitParam尤其關鍵),用以自動生成文檔:mvc
@RestController @RequestMapping("/config") @Api(description = "配置管理接口") @Slf4j public class ConfigAction { @PostMapping("/set") @ApiOperation(value = "更改或新增配置信息") @ApiResponses(value = { @ApiResponse(code = 500, message = "系統錯誤"), @ApiResponse(code = 0, message = "成功") }) @ApiImplicitParams({ @ApiImplicitParam(name = "key", value = "鍵", paramType = "form", dataType = "string"), @ApiImplicitParam(name = "value", value = "值", paramType = "form", dataType = "string") }) public ActionMessage setConfig(String key, String value) { log.debug("key: {}, value: {}", key, value); ConfigUtil.setConfig(key, value); return ActionStatus.success(); } @GetMapping("/get") @ApiOperation(value = "獲取配置信息") @ApiImplicitParam(name = "key", value = "鍵", paramType = "query", dataType = "string") public Map<String, Object> getConfig(String key) { Object value = ConfigUtil.getConfig(key); log.debug("key: {}, value: {}", key, value); Map<String, Object> map = new HashMap<>(); map.put(key, value); return map; } }
啓動項目,訪問http://{host:port}/{project}/swagger-ui.html查看配置是否生效:app
看上去沒有問題,測試下:
ps:網上關於swagger的文章配置上多數都有些問題,因此不能直接照搬使用。本身部署swagger時要根據實際項目來修改配置,好比spring、swagger的版本等。