第一步:导入核心包
<!--swagger-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<scope>provided </scope>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<scope>provided </scope>
</dependency>
第二步:创建配置文件
import com.google.common.base.Predicates;
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.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;
@Configuration//配置类
@EnableSwagger2 //swagger注解
public class SwaggerConfig {
@Bean
public Docket webApiConfig(){
return new Docket(DocumentationType.SWAGGER_2)
.groupName("webApi")
.apiInfo(webApiInfo())
.select()
.paths(Predicates.not(PathSelectors.regex("/admin/.*")))
.paths(Predicates.not(PathSelectors.regex("/error.*")))
.build();
}
private ApiInfo webApiInfo(){
return new ApiInfoBuilder()
.title("网站-课程中心API文档")
.description("本文档描述了课程中心微服务接口定义")
.version("1.0")
.contact(new Contact("java", "http://xcm.com", "[email protected]"))
.build();
}
}
第三步:编写测试接口
/**
* <p>
* 讲师 前端控制器
* </p>
*
* @author testjava
* @since 2020-06-15
*/
@Api(description = "讲师管理")
@RestController
@RequestMapping("/eduservice/teacher")
public class EduTeacherController {
// 注入service
@Autowired
private EduTeacherService teacherService;
// 查询所有讲师数据
@ApiOperation(value = "所有讲师列表")
@GetMapping("findAll")
public List<EduTeacher> findAllTeacher(){
List<EduTeacher> list = teacherService.list(null);
return list;
}
// 逻辑删除讲师
@ApiOperation(value = "逻辑删除讲师")
@DeleteMapping("{id}")
public boolean removeTeacher(@ApiParam(name = "id", value = "讲师ID", required = true) @PathVariable String id){
boolean flag = teacherService.removeById(id);
return flag;
}
}
第四步:测试接口
访问:http://localhost:8001/swagger-ui.html
细节注意:
1、如果有分包的情况或者配置类不在启动类所在的子目录下,要添加这个
@ComponentScan(basePackages = {“com.xcm”})
注解,不然扫描不到这个配置类
2、Swagger的作用本质上和postman差不多,都是测试接口用的
3、这三个都是Swagger的注解类,作用是用于功能提示,提高接口文档的可视化
@Api(description = “讲师管理”)
@ApiOperation(value = “所有讲师列表”)
@ApiParam(name = “id”, value = “讲师ID”, required = true)
分别作用在类、方法、参数上