1.前提
一定要看好版本。
Springboot ✚ Swagger各版本整理_swagger版本_qq_33334411的博客-CSDN博客
我的版本:
<dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artifactId><version>3.0.0</version></dependency>
2. 使用
新建一个boot web项目之后,导入上述依赖。
在confi包下新建一个SwaggerConfig.java配置类
Swgger2Config.java
@Configuration
@EnableSwagger2 // 3.0版本加不加无所谓
public class Swagger2Config {@Beanpublic Docket coreApiConfig(){return new Docket(DocumentationType.SWAGGER_2).apiInfo(adminApiInfo()).groupName("group1").select().build();}private ApiInfo adminApiInfo(){return new ApiInfoBuilder().title("后台管理系统--api文档").description("后台管理系统接口描述").version("1.0").contact(new Contact("郡主喵","http://baidu.com","728831102@qq.com")).build();}
}
在controller包新建HelloController.java
@RestController
@ResponseBody
@Api(tags = "你好相关接口:")
public class HelloController {@GetMapping("/hellow")@ApiOperation("这是一个测试接口")public HelloVO hello(){return new HelloVO("qhx",11);}
}
在modle.vo下新建HelloVO.java
@ApiModel(value = "HelloVO",description = "你好相关接口的信息封装")
public class HelloVO {@ApiModelProperty("姓名")private String name;@ApiModelProperty("年龄")private Integer age;public String getName() {return name;}public Integer getAge() {return age;}public void setName(String name) {this.name = name;}public void setAge(Integer age) {this.age = age;}public HelloVO(String name, Integer age) {this.name = name;this.age = age;}
}
在application.yml/properties文件中添加
spring:mvc:pathmatch:matching-strategy: ant_path_matcher
运行,访问 http://localhost:8081/swagger-ui/index.html
看到如上,及成功。
一般常用的swagger2注解:
@Api:修饰整个类,描述Controller的作用
@ApiOperation:描述一个类的一个方法,或者说一个接口
@ApiParam:单个参数描述
@ApiModel:用对象来接收参数
@ApiModelProperty:用对象接收参数时,描述对象的一个字段
@ApiImplicitParam:一个请求参数 @ApiImplicitParams:多个请求参数
3.报错解决
1.Unable to start web server; nested exception is org.springframework.context.ApplicationContextException: Unable to start ServletWebServerApplicationContext due to missing ServletWebServerFactory bean.
忘加这个。
2. Failed to start bean 'documentationPluginsBootstrapper'; nested exception is java.lang.NullPointerException
SpringBoot2.6.x使用PathPatternMatcher匹配路径,Swagger引用的Springfox基于AntPathMatcher匹配路径。匹配方式不同,导致错误。
因此在application.yaml/properties 文件新加。
spring:mvc:pathmatch:matching-strategy: ant_path_matcher
3.访问页面为空
你项目中加了拦截器,需要在拦截器相应的放行静态资源。
springboot集成swagger页面空白解决方法_swagger 空白_立码收复恶眛里恳的博客-CSDN博客