当前位置: 首页 > wzjs >正文

江苏中星建设集团网站数字营销网站

江苏中星建设集团网站,数字营销网站,门头广告设计图片,外贸网站制作教程问题: 需求父子项目swagger扫描多个子模块中的Controller生成接口文档: Swagger2Knife4jConfig 配置放在了 springboot-app 启动项目里,而 tiger-web 和 tiger-web2 这两个子项目有自己的 Controller。这种情况下,Swagger 可能无法正确扫描 tiger-web 和…

问题:

需求父子项目swagger扫描多个子模块中的Controller生成接口文档:

在这里插入图片描述

Swagger2Knife4jConfig 配置放在了 springboot-app 启动项目里,而 tiger-web 和 tiger-web2 这两个子项目有自己的 Controller。这种情况下,Swagger 可能无法正确扫描 tiger-web 和 tiger-web2 里的接口。你可以尝试以下几种方式来正确配置 Swagger(Knife4j)

确保 tiger-web 和 tiger-web2 里的 Controller 加上 @Api

例如:

package com.zz.web.controller;import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@Api(tags = "测试接口")
@RestController
@RequestMapping("/test")
public class TestController {@ApiOperation(value = "获取测试信息")@GetMapping("/info")public String getInfo() {return "Hello Swagger!";}
}
这样,Swagger 就能扫描到 tiger-web 和 tiger-web2 里的接口了。

方案 1:修改 Swagger2Knife4jConfig,支持多个模块

  1. 修改 Swagger2Knife4jConfig,扫描所有子模块 @ComponentScan(basePackages = {"com.zz.web", "com.zz.web2"}) // 扫描 web 和 web2 模块

你需要确保 Swagger2Knife4jConfig 能扫描 tiger-web 和 tiger-web2 里的 Controller。可以使用 @ComponentScan,或者修改 Docket 里的 basePackage。

package com.zz.app.config;import io.swagger.annotations.Api;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.context.annotation.ComponentScan;
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.EnableSwagger2WebMvc;import java.util.Collections;@Configuration
@EnableSwagger2WebMvc
@ComponentScan(basePackages = {"com.zz.web", "com.zz.web2"}) // 扫描 web 和 web2 模块
public class Swagger2Knife4jConfig {@Beanpublic Docket createRestApi() {return new Docket(DocumentationType.SWAGGER_2).protocols(Collections.singleton("https")).host("https://www.tiger.com").apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.withClassAnnotation(Api.class)) // 只扫描有 @Api 注解的 Controller.paths(PathSelectors.any()).build();}private ApiInfo apiInfo() {return new ApiInfoBuilder().title("tiger-api文档").description("springboot项目").contact(new Contact("tiger", "https://tiger", "tiger@qq.com")).termsOfServiceUrl("https://www.tiger.com/api").version("1.0").build();}
}

方案 2:在每个子模块 (tiger-web 和 tiger-web2) 里单独配置 Swagger

如果 tiger-web 和 tiger-web2 是独立的服务(分别启动),你可以在 tiger-web 和 tiger-web2 里分别配置 Swagger,而不是放到 springboot-app 里。
在 tiger-web 里新建 Swagger2Knife4jConfig.java

package com.zz.web.config;import io.swagger.annotations.Api;
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.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.EnableSwagger2WebMvc;@Configuration
@EnableSwagger2WebMvc
public class Swagger2Knife4jConfig {@Beanpublic Docket createRestApi() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.basePackage("com.zz.*.controller")) // 仅扫描 web 模块的 Controller.paths(PathSelectors.any()).build();}private ApiInfo apiInfo() {return new ApiInfoBuilder().title("tiger-web API 文档").description("tiger-web 模块接口文档").contact(new Contact("tiger", "https://tiger", "tiger@qq.com")).version("1.0").build();}
}

然后,在 tiger-web2 里也创建一个类似的 Swagger2Knife4jConfig.java,修改 basePackage 为 com.zz.web2.controller。

方案 3:使用 @Import 让 springboot-app 统一加载多个模块的 Swagger 配置

你可以把 Swagger2Knife4jConfig 移动到 tiger-config 里,然后在 springboot-app 里用 @Import 引入。
在 tiger-config 里新建 Swagger2Knife4jConfig.java

package com.zz.config;import io.swagger.annotations.Api;
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.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.EnableSwagger2WebMvc;@Configuration
@EnableSwagger2WebMvc
public class Swagger2Knife4jConfig {@Beanpublic Docket createRestApi() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.withClassAnnotation(Api.class)) .paths(PathSelectors.any()).build();}private ApiInfo apiInfo() {return new ApiInfoBuilder().title("统一 API 文档").description("springboot-app 统一 API").contact(new Contact("tiger", "https://tiger", "tiger@qq.com")).version("1.0").build();}
}

在 springboot-app 里引入 Swagger2Knife4jConfig

package com.zz.app;import com.zz.config.Swagger2Knife4jConfig;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Import;@SpringBootApplication
@Import(Swagger2Knife4jConfig.class)
public class SpringbootAppApplication {public static void main(String[] args) {SpringApplication.run(SpringbootAppApplication.class, args);}
}

这样,springboot-app 启动后,Swagger 也能扫描 tiger-web 和 tiger-web2 里的 Controller 了。

结论

如果 tiger-web 和 tiger-web2 是 独立的服务,建议 方案 2,每个模块独立配置 Swagger。如果 springboot-app 统一启动所有模块,建议 方案 1 或 方案 3

子模块过多可以设置分组

通过 groupName 在 Docket 配置中进行区分。因为你的 tiger-web 和 tiger-web2 都有 Controller,可以在 Swagger2Knife4jConfig 里为每个子项目单独创建 Docket,分别设置不同的 groupName。

package com.zz.app.swaggerConfig;import io.swagger.annotations.Api;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
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.EnableSwagger2WebMvc;import java.util.Collections;/*** Knife4j配置类** @author tiger*/
@Configuration
@EnableSwagger2WebMvc
@ComponentScan(basePackages = {"com.zz.*"}) // 注意必须加: 扫描 web 和 web2 模块
public class Swagger2Knife4jConfig {@Beanpublic Docket webApi() {return new Docket(DocumentationType.SWAGGER_2).groupName("tiger-web")  // 分组名称.protocols(Collections.singleton("https")).host("https://www.tiger.com").apiInfo(apiInfo("tiger-web API文档")).select()
//                .apis(RequestHandlerSelectors.withClassAnnotation(Api.class)).apis(RequestHandlerSelectors.basePackage("com.zz.web.controller")) // 修改为实际的controller包路径.paths(PathSelectors.any()).build();}@Beanpublic Docket web2Api() {return new Docket(DocumentationType.SWAGGER_2).groupName("tiger-web2")  // 分组名称.protocols(Collections.singleton("https")).host("https://www.tiger.com").apiInfo(apiInfo("tiger-web2 API文档")).select()
//                .apis(RequestHandlerSelectors.withClassAnnotation(Api.class)).apis(RequestHandlerSelectors.basePackage("com.zz.web2.controller")) // 修改为实际的controller包路径.paths(PathSelectors.any()).build();}private ApiInfo apiInfo(String title) {return new ApiInfoBuilder().title(title).description("springboot项目").contact(new Contact("tiger", "https://tiger", "tiger@qq.com")).termsOfServiceUrl("https://www.tiger.com/api").version("1.0").build();}
}
http://www.dtcms.com/wzjs/205141.html

相关文章:

  • 做网站用什么虚拟主机爱站网关键词搜索
  • iis7.0搭建网站知乎营销推广
  • win10做的网站其他电脑访问不了it培训机构哪家好
  • 舞蹈东莞网站建设国外免费网站域名服务器
  • 深圳市建设交易中心网站首页北京网站制作建设公司
  • 适合seo优化的网站制作简单网页制作模板
  • 政府网站数字化建设方案网络赚钱推广
  • 迷你主机做网站服务器淘宝指数查询工具
  • 潍坊高端网站建设网络营销的重要性与意义
  • 公司网站修改怎么做找人帮忙注册app推广
  • 制作网站服务器杭州网站建设网页制作
  • 白银做网站营销软件app
  • 网站建设及管理网站网络推广企业
  • 重庆大渡口建设网站新闻稿营销
  • 网站托管方案营销策划公司是干什么的
  • 小程序开发需求方案东莞seo外包平台
  • 网站建设与网页设计 教材360营销平台
  • 营销型网站设计报价官网seo哪家公司好
  • 辽宁响应式网站建设推荐baidu百度首页官网
  • 有没有做生物科技相关的网站广告推广方案怎么写
  • 中国空间站有哪些国家加入重庆网站seo技术
  • 武汉做装饰公司网站平台百度热搜广告设计公司
  • 建设网站哪个好超级外链吧
  • 免费建站团队怎么做信息流广告代理商
  • 卖环保设备做哪个网站好2021年网络热点舆论
  • 贵州省住房和城乡建设管理委员会网站网店代运营的套路
  • 房山富阳网站建设google play下载
  • 做一的同志小说网站有哪些怎么制作自己的网站网页
  • 什么网站做批发凉席seo外链网
  • 做安利能开个人网站正规网络教育培训机构