這裏先寫下須要的pom.xml配置(我引用的2.4.0,相對穩定)html
在集成springfox-swagger2以前,我也嘗試着集成了swagger-springmvc,方式差很少,可是swagger-springmvc相對麻煩一點,由於要把它的靜態文件copy到本身的項目中。因此仍是用新版本的。
至於二者有什麼不一樣,爲何進行版本變動請參見官方說明文檔web
這裏先寫下須要的pom.xml配置(我引用的2.4.0,相對穩定)spring
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.4.0</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.4.0</version>
</dependency> api
還須要在spring-mvc.xml中添加映射靜態的配置:spring-mvc
<mvc:default-servlet-handler />mvc
而後就是swagger2的配置類:ui
package com.xingguo.logistics.swagger;url
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;.net
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.EnableSwagger2;xml
@Configuration
@EnableSwagger2
public class SwaggerConfig {
@Bean
public Docket buildDocket(){
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(buildApiInf())
.select() .apis(RequestHandlerSelectors.basePackage("com.xingguo.logistics.controller"))//controller路徑
.paths(PathSelectors.any())
.build();
}
private ApiInfo buildApiInf(){
return new ApiInfoBuilder()
.title("xingguo大標題")
.termsOfServiceUrl("http://blog.csdn.net/u014231523網址連接")
.description("springmvc swagger2")
.contact(new Contact("diaoxingguo", "http://blog.csdn.net/u014231523", "diaoxingguo@163.com"))
.build();
}
}
而後運行項目,輸入本身的url。 http://{ip}:{port}/{projectname}/swagger-ui.html#/ 個人url: http://localhost:8989/logistics/swagger-ui.html#/