文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

spring-gateway网关聚合swagger实现多个服务接口切换的方法

2023-06-29 09:32

关注

本文小编为大家详细介绍“spring-gateway网关聚合swagger实现多个服务接口切换的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“spring-gateway网关聚合swagger实现多个服务接口切换的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

前提条件

微服务已经集成了swagger,并且注册进了nacos。

gateway配置

package com.zmy.springcloud.config;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Value;import org.springframework.cloud.gateway.route.RouteLocator;import org.springframework.stereotype.Component;import springfox.documentation.swagger.web.SwaggerResource;import springfox.documentation.swagger.web.SwaggerResourcesProvider;import java.util.*;@Componentpublic class MySwaggerResourceProvider implements SwaggerResourcesProvider {        private static final String SWAGGER2URL = "/v2/api-docs";        private final RouteLocator routeLocator;        @Value("${spring.application.name}")    private String self;    @Autowired    public MySwaggerResourceProvider(RouteLocator routeLocator) {        this.routeLocator = routeLocator;    }    @Override    public List<SwaggerResource> get() {        List<SwaggerResource> resources = new ArrayList<>();        List<String> routeHosts = new ArrayList<>();        // 获取所有可用的host:serviceId        routeLocator.getRoutes().filter(route -> route.getUri().getHost() != null)                .filter(route -> !self.equals(route.getUri().getHost()))                .subscribe(route -> routeHosts.add(route.getUri().getHost()));        // 记录已经添加过的server        Set<String> dealed = new HashSet<>();        routeHosts.forEach(instance -> {            // 拼接url            String url = "/" + instance.toLowerCase() + SWAGGER2URL;            if (!dealed.contains(url)) {                dealed.add(url);                SwaggerResource swaggerResource = new SwaggerResource();                swaggerResource.setUrl(url);                swaggerResource.setName(instance);                resources.add(swaggerResource);            }        });        return resources;    }}
package com.zmy.springcloud.config.swagger.controller;import com.zmy.springcloud.config.MySwaggerResourceProvider;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.http.HttpStatus;import org.springframework.http.ResponseEntity;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import springfox.documentation.swagger.web.*;import java.util.List;@RestController@RequestMapping("/swagger-resources")public class SwaggerResourceController {    private MySwaggerResourceProvider swaggerResourceProvider;    @Autowired    public SwaggerResourceController(MySwaggerResourceProvider swaggerResourceProvider) {        this.swaggerResourceProvider = swaggerResourceProvider;    }    @RequestMapping(value = "/configuration/security")    public ResponseEntity<SecurityConfiguration> securityConfiguration() {        return new ResponseEntity<>(SecurityConfigurationBuilder.builder().build(), HttpStatus.OK);    }    @RequestMapping(value = "/configuration/ui")    public ResponseEntity<UiConfiguration> uiConfiguration() {        return new ResponseEntity<>(UiConfigurationBuilder.builder().build(), HttpStatus.OK);    }    @RequestMapping    public ResponseEntity<List<SwaggerResource>> swaggerResources() {        return new ResponseEntity<>(swaggerResourceProvider.get(), HttpStatus.OK);    }}
<dependency>    <groupId>org.springframework.cloud</groupId>    <artifactId>spring-cloud-starter-gateway</artifactId></dependency><!--swagger生成API文档--><dependency>    <groupId>io.springfox</groupId>    <artifactId>springfox-swagger2</artifactId>    <version>2.9.2</version>    <exclusions>        <exclusion>            <groupId>io.swagger</groupId>            <artifactId>swagger-models</artifactId>        </exclusion>    </exclusions></dependency><dependency>    <groupId>io.swagger</groupId>    <artifactId>swagger-models</artifactId>    <version>1.5.22</version></dependency><dependency>    <groupId>io.springfox</groupId>    <artifactId>springfox-swagger-ui</artifactId>    <version>2.9.2</version></dependency><!--nacos--><dependency>    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
server:  port: 9527spring:  application:    name: cloud-gateway  cloud:    gateway:      routes:        - id: seata-storage-service          uri: lb://seata-storage-service          predicates:            - Path=/seata-storage-service/**         # 断言,相匹配的进行路由          filters:            - StripPrefix=1        - id: seata-account-service          uri: lb://seata-account-service            - Path=/seata-account-service/**      discovery:        locator:          enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由    nacos:        server-addr: localhost:8848

- StripPrefix=1是必须配置的,跳过- Path的第一段路径。

http://localhost:2003/v2/api-docs 这个是正确的swagger数据请求地址。不加- StripPrefix=1的话,swagger在请求数据时候会请求http://localhost:2003/seata-account-service/v2/api-docs,这样就会请求不到数据。

spring-gateway网关聚合swagger实现多个服务接口切换的方法

如果不加- StripPrefix=1,也有其他的解决方案,可以在微服务提供者中配置服务上下文路径

server:  servlet:    context-path: /seata-order-service

注意网关的拦截器,不要将swagger请求拦截掉。

读到这里,这篇“spring-gateway网关聚合swagger实现多个服务接口切换的方法”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯