前言:html
在以前的項目中用了將近一年的RAP,RAP是由阿里開源出來的,很是好用。github地址:https://github.com/thx/RAP。git
當初在用此工具時,項目成員須要在接口文檔在所改動後,發郵件到項目組成員,因爲rap當時沒有此功能,因此還下載源碼,增長了發郵件功能。github
將此功能代碼commit到了社區,好像社區沒有接納合入。 web
後來使用了一年後,發現了swagger彷佛使用很方便,直接跟代碼進行結合,須要從新使用其餘工具進行配合了。spring
因此如下時對swagger的spring集成說明。api
swagger集成spring說明:springboot
若是是在springboot集成swagger是很是方便和簡單的,在網上一搜,或者到官網一看就明白了,這裏不在贅述。mvc
如下主要是本身集成到springmvc的改造點:ide
一、pom.xm文件,須要增長如下的依賴:工具
版本爲:
<jackson-version>2.5.0</jackson-version>
<swagger-springmvc-version>1.0.2</swagger-springmvc-version>
增長的依賴爲,:
<!-- 自動生成接口文檔工具 -->
<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>
<!-- 自動生成接口文檔工具 -->
<!-- 集成swagger2須要用到 通常都用fastJson,可是swagger是用到jackson的-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>${jackson-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>
<!-- 集成swagger2須要用到 -->
2.增長一個swagger的配置文件:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import springfox.documentation.builders.ApiInfoBuilder;
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.EnableSwagger2;
/**
* Swagger接口自動生成工具的配置
*
* @author liuhangjun
* @date 2017-01-22
*/
@Configuration
@EnableWebMvc
@EnableSwagger2
@ComponentScan("com.gradven.portalapi.controller")
public class SwaggerConfig extends WebMvcConfigurerAdapter {
@Bean
public Docket api() {
return new Docket(DocumentationType.SWAGGER_2).select()
.apis(RequestHandlerSelectors.basePackage("com.gradven.portalapi.controller")).build()
.apiInfo(apiInfo());
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
// 頁面標題
.title("api門戶 使用 Swagger2 構建RESTful API")
// 建立人
.contact(new Contact("gradven", null, "xxxxxxx@126.com"))
// 版本號
.version("1.0")
// 描述
.description("門戶接口").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/");
}
}
3.在spring的配置文件中將以上這個類進行注入:
<!-- swagger 配置 -->
<bean class="com.gradven.portalapi.commons.config.SwaggerConfig"/>
4.編寫controller,訪問swagger:
只要在com.gradven.portalapi.controller這個包下,編寫controller,那麼再訪問http://localhost:port/swagger-ui.htm就能夠看到接口了。