2024.5.30 Thursday
接上文【WEEK14】 【DAY3】Swagger第一部分【中文版】
目录
- 16.4.配置扫描接口
- 16.4.1.修改SwaggerConfig.java
- 16.4.1.1.使用.basePackage()方法指定扫描的包路径
- 16.4.1.2.其他扫描方式均可在RequestHandlerSelectors.class中查看源码
- 16.4.2.仍然是修改SwaggerConfig.java
- 16.4.2.1.配置接口扫描过滤
- 16.4.2.2.其他方法:
- 16.5.配置Swagger开关
- 16.5.1.修改enable的值关闭使用swagger
- 16.5.2.动态配置当项目处于test、dev环境时显示swagger,处于prod时不显示
- 16.5.2.1.修改SwaggerConfig
- 16.5.2.2.修改application.properties
- 16.5.2.3.新建application-dev.properties
- 16.5.2.4.新建application-pro.properties
- 16.5.2.5.重启
16.4.配置扫描接口
构建Docket时通过select()方法配置扫描接口的方式
16.4.1.修改SwaggerConfig.java
16.4.1.1.使用.basePackage()方法指定扫描的包路径
package com.P47.config;import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
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;import java.util.ArrayList;@Configuration //等价于@Component
@EnableSwagger2 //开启Swagger2
public class SwaggerConfig {//配置了Swagger的bean实例Docket,以配置Swagger的具体参数@Beanpublic Docket docket(){return new Docket(DocumentationType.SWAGGER_2) //源码见DocumentationType.classpublic class DocumentationType extends SimplePluginMetadata方法,选择符合当前版本的进行编辑.apiInfo(apiInfo()) //public Docket(DocumentationType documentationType)方法点开ApiInfo进入ApiInfo.class.select() //通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口.apis(RequestHandlerSelectors.basePackage("com.P47.controll")).build();//点击进入Docket.class可见各类方法源码}//配置Swagger信息(apiInfo)private ApiInfo apiInfo(){//防止DEFAULT_CONTACT(名字改成了contact)报错Contact contact = new Contact("联系人名字", "联系人访问链接", "联系人邮箱");return new ApiInfo("Swagger Api Documentation", //标题"Api Documentation 描述", //描述"version 1.0", //版本号"http://terms.service.url", //组织链接contact, //联系人信息"Apache 2.0", //许可"http://www.apache.org/licenses/LICENSE-2.0", //许可链接new ArrayList<>() //扩展);}
}
重启后查看:只剩hello-controller栏
16.4.1.2.其他扫描方式均可在RequestHandlerSelectors.class中查看源码
basePackage(final String basePackage) // 根据包路径扫描接口
any() // 扫描所有,项目中的所有接口都会被扫描到
none() // 不扫描接口withMethodAnnotation(final Class<? extends Annotation> annotation) // 通过方法上的注解扫描,如withMethodAnnotation(GetMapping.class)只扫描get请求
withClassAnnotation(final Class<? extends Annotation> annotation) // 通过类上的注解扫描,如.withClassAnnotation(Controller.class)只扫描有controller注解的类中的接口
16.4.2.仍然是修改SwaggerConfig.java
16.4.2.1.配置接口扫描过滤
添加以下过滤
.paths(PathSelectors.ant("/P47/**")) //点击path查看初始化private Predicate<String> pathSelector; 这里以.ant()方法为例,只扫描请求以/P47开头的接口
重启后查看:没有显示任何方法
16.4.2.2.其他方法:
此时修改后的完整代码
package com.P47.config;import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
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;import java.util.ArrayList;@Configuration //等价于@Component
@EnableSwagger2 //开启Swagger2
public class SwaggerConfig {//配置了Swagger的bean实例Docket,以配置Swagger的具体参数@Beanpublic Docket docket(){return new Docket(DocumentationType.SWAGGER_2) //源码见DocumentationType.classpublic class DocumentationType extends SimplePluginMetadata方法,选择符合当前版本的进行编辑.apiInfo(apiInfo()) //public Docket(DocumentationType documentationType)方法点开ApiInfo进入ApiInfo.class.select() //通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口.apis(RequestHandlerSelectors.basePackage("com.P47.controll")) //使用basePackage指定要扫描的包.paths(PathSelectors.ant("/P47/**")) //点击path查看初始化private Predicate<String> pathSelector; 这里以.ant()方法为例,只扫描请求以/P47开头的接口.build();//点击进入Docket.class可见各类方法源码/*RequestHandlerSelectors.方法basePackage(final String basePackage) // 根据包路径扫描接口any() // 扫描所有,项目中的所有接口都会被扫描到none() // 不扫描接口withMethodAnnotation(final Class<? extends Annotation> annotation) // 通过方法上的注解扫描,如withMethodAnnotation(GetMapping.class)只扫描get请求withClassAnnotation(final Class<? extends Annotation> annotation) // 通过类上的注解扫描,如.withClassAnnotation(Controller.class)只扫描有controller注解的类中的接口*//*PathSelectors.方法any() // 任何请求都扫描none() // 任何请求都不扫描regex(final String pathRegex) // 通过正则表达式控制ant(final String antPattern) // 通过ant()控制*/}//配置Swagger信息(apiInfo)private ApiInfo apiInfo(){//防止DEFAULT_CONTACT(名字改成了contact)报错Contact contact = new Contact("联系人名字", "联系人访问链接", "联系人邮箱");return new ApiInfo("Swagger Api Documentation", //标题"Api Documentation 描述", //描述"version 1.0", //版本号"http://terms.service.url", //组织链接contact, //联系人信息"Apache 2.0", //许可"http://www.apache.org/licenses/LICENSE-2.0", //许可链接new ArrayList<>() //扩展);}
}
16.5.配置Swagger开关
修改SwaggerConfig.java
16.5.1.修改enable的值关闭使用swagger
@Bean
public Docket docket(){return new Docket(DocumentationType.SWAGGER_2) //源码见DocumentationType.classpublic class DocumentationType extends SimplePluginMetadata方法,选择符合当前版本的进行编辑.apiInfo(apiInfo()) //public Docket(DocumentationType documentationType)方法点开ApiInfo进入ApiInfo.class.enable(false) //是否启动swagger,false则不能启动,此时访问页面显示:😱 Could not render e, see the console..select() //通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口//.apis(RequestHandlerSelectors.basePackage("com.P47.controll")) //使用basePackage指定要扫描的包//.paths(PathSelectors.ant("/P47/**")) //点击path查看初始化private Predicate<String> pathSelector; 这里以.ant()方法为例,只扫描请求以/P47开头的接口.build();}
重启:
16.5.2.动态配置当项目处于test、dev环境时显示swagger,处于prod时不显示
16.5.2.1.修改SwaggerConfig
@Bean
public Docket docket(Environment environment){// 设置要显示swagger的环境Profiles profiles = Profiles.of("dev", "test");// 判断当前是否处于该环境// 通过 enable() 接收此参数判断是否要显示boolean flag = environment.acceptsProfiles(profiles);return new Docket(DocumentationType.SWAGGER_2) //源码见DocumentationType.classpublic class DocumentationType extends SimplePluginMetadata方法,选择符合当前版本的进行编辑.apiInfo(apiInfo()) //public Docket(DocumentationType documentationType)方法点开ApiInfo进入ApiInfo.class.enable(flag) //是否启动swagger,false则不能启动,此时访问页面显示:😱 Could not render e, see the console..select() //通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口//.apis(RequestHandlerSelectors.basePackage("com.P47.controll")) //使用basePackage指定要扫描的包//.paths(PathSelectors.ant("/P47/**")) //点击path查看初始化private Predicate<String> pathSelector; 这里以.ant()方法为例,只扫描请求以/P47开头的接口.build();}
此时完整的代码:
package com.P47.config;import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
import org.springframework.core.env.Profiles;
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;import java.util.ArrayList;@Configuration //等价于@Component
@EnableSwagger2 //开启Swagger2
public class SwaggerConfig {//配置了Swagger的bean实例Docket,以配置Swagger的具体参数@Beanpublic Docket docket(Environment environment){// 设置要显示swagger的环境Profiles profiles = Profiles.of("dev", "test");// 判断当前是否处于该环境// 通过 enable() 接收此参数判断是否要显示boolean flag = environment.acceptsProfiles(profiles);return new Docket(DocumentationType.SWAGGER_2) //源码见DocumentationType.classpublic class DocumentationType extends SimplePluginMetadata方法,选择符合当前版本的进行编辑.apiInfo(apiInfo()) //public Docket(DocumentationType documentationType)方法点开ApiInfo进入ApiInfo.class.enable(flag) //是否启动swagger,false则不能启动,此时访问页面显示:😱 Could not render e, see the console..select() //通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口//.apis(RequestHandlerSelectors.basePackage("com.P47.controll")) //使用basePackage指定要扫描的包//.paths(PathSelectors.ant("/P47/**")) //点击path查看初始化private Predicate<String> pathSelector; 这里以.ant()方法为例,只扫描请求以/P47开头的接口.build();}//配置Swagger信息(apiInfo)private ApiInfo apiInfo(){//防止DEFAULT_CONTACT(名字改成了contact)报错Contact contact = new Contact("联系人名字", "联系人访问链接", "联系人邮箱");return new ApiInfo("Swagger Api Documentation", //标题"Api Documentation 描述", //描述"version 1.0", //版本号"http://terms.service.url", //组织链接contact, //联系人信息"Apache 2.0", //许可"http://www.apache.org/licenses/LICENSE-2.0", //许可链接new ArrayList<>() //扩展);}
}
16.5.2.2.修改application.properties
spring.application.name=swagger-demo
spring.mvc.pathmatch.matching-strategy=ant_path_matcher
spring.profiles.active=dev
16.5.2.3.新建application-dev.properties
#生产环境
server.port=8081
16.5.2.4.新建application-pro.properties
#测试环境
server.port=8082
16.5.2.5.重启
访问http://localhost:8081/swagger-ui.html
将application.properties中配置改为spring.profiles.active=pro,访问http://localhost:8082/swagger-ui.html无法进入swagger页面。
同理,如果不写spring.profiles.active指定文件,默认端口是8080,由于此时在SwaggerConfig中的配置,http://localhost:8080/swagger-ui.html也不可访问swagger。