Springcloud Gateway配置步骤图解如何绘制?

2026-04-30 09:472阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1245个文字,预计阅读时间需要5分钟。

Springcloud Gateway配置步骤图解如何绘制?

为了不暴露个人信息等敏感信息,我们可以选择一个网关在前面进行阻挡,起到保护的作用。以下是一个简化的示例:

通常为了不暴露个人信息等敏感信息,会选用一个网关在前面对接,起到保护作用。例如,配置网关9527,作为网关使用,需要和其他应用一样,注册到Eureka。

附上工作示意图:+-----------------+ +-----------------+ +-----------------+| 应用服务1 | --> | 网关9527 | --> | 应用服务2 |+-----------------+ +-----------------+ +-----------------+图示说明:- 应用服务1和2通过网关9527进行通信。- 网关9527作为入口,对请求进行路由和过滤,保护内部应用服务。

一般为了不暴露自己的端口信息等,会选择架构一个网关在前面进行阻挡,起到保护的作用。附上一张工作示列图。

1.配置网关9527

gateway作为网关需要和其他的应用一样需要注册进eureka中进行管理,先创建应用gateway9527

pom文件,关键是gateway依赖

<dependencies> <dependency> <groupId>com.bai</groupId> <artifactId>cloud-api-common</artifactId> <version>${project.version}</version> </dependency> <!--gateway--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> <!--eureka client--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <!--热部署--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>

yml文件配置

server: port: 9527 spring: application: name: cloud-gateway cloud: gateway: discovery: locator: enabled: true # 开启从注册中心动态创建路由的功能,利用微服务名称进行路由 routes: - id: payment_route # 路由的id,没有规定规则但要求唯一,建议配合服务名 #匹配后提供服务的路由地址 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/get/** # 断言,路径相匹配的进行路由 - id: payment_route2 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/sp/** #断言,路径相匹配的进行路由 eureka: instance: hostname: cloud-gateway-service client: fetch-registry: true register-with-eureka: true service-url: defaultZone: eureka7001.com:7001/eureka/

主启动类正常配置

@SpringBootApplication @EnableEurekaClient public class GateWay9527 { public static void main(String[] args) { SpringApplication.run(GateWay9527.class,args); } }

2.配置路由两种方式

1)yml文件格式(推荐)

spring: application: name: cloud-gateway cloud: gateway: discovery: locator: enabled: true # 开启从注册中心动态创建路由的功能,利用微服务名称进行路由 routes: - id: payment_route # 路由的id,没有规定规则但要求唯一,建议配合服务名 #匹配后提供服务的路由地址 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/get/** # 断言,路径相匹配的进行路由 - id: payment_route2 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/sp/** #断言,路径相匹配的进行路由 - After=2020-11-09T11:09:52.794+08:00[Asia/Shanghai] - Cookie=username,bai #带Cookie,并且username的值为bai # - Header=X-Request-Id,\d+ #请求头要有 X-Request-Id属性并且值为整数的正则表达式

2)通过config配置类实现

@Configuration public class RouteConfig { @Bean public RouteLocator customerRoute(RouteLocatorBuilder builder){ RouteLocatorBuilder.Builder routes = builder.routes(); routes.route("payment_route1", r -> r.path("/guonei").uri("news.baidu.com/guonei")).build(); return routes.build(); } @Bean public RouteLocator bokeRoute(RouteLocatorBuilder builder){ RouteLocatorBuilder.Builder routes = builder.routes(); routes.route("payment_route2",r->r.path("/boke").uri("www.cnblogs.com/lin530/")).build(); return routes.build(); } }

3.断言(Predicate)

相当于多种限制,只有通过验证才能够访问到对应的方法

- id: payment_route2 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/sp/** #断言,路径相匹配的进行路由 - After=2020-11-09T11:09:52.794+08:00[Asia/Shanghai] - Cookie=username,bai #带Cookie,并且username的值为bai # - Header=X-Request-Id,\d+ #请求头要有 X-Request-Id属性并且值为整数的正则表达式

不同的方法可以配置不同的断言,此处的断言需要满足路径对,after时间后,cookie带上正确的用户名才可以访问到,用cmd测试

Springcloud Gateway配置步骤图解如何绘制?

其他还有很多断言,请对照文档自行研究

4)过滤(filter)

对访问加上限制,通过验证才可以访问

新建过滤配置类

@Component @Slf4j public class GatewayGlobalFilter implements GlobalFilter, Ordered { @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { log.info("***time is :"+new Date()); String uname = exchange.getRequest().getQueryParams().getFirst("uname"); if(uname==null){ log.info("没有用户名,出现错误:o(╥﹏╥)o"); exchange.getResponse().setStatusCode(HttpStatus.NOT_ACCEPTABLE); return exchange.getResponse().setComplete(); } return chain.filter(exchange); } /* 设置过滤器优先级,越小优先级越大 */ @Override public int getOrder() { return 0; } }

访问方式带上参数,

本篇所有代码均在GitHub:

github.com/MaTsukun/springcloud2020

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计1245个文字,预计阅读时间需要5分钟。

Springcloud Gateway配置步骤图解如何绘制?

为了不暴露个人信息等敏感信息,我们可以选择一个网关在前面进行阻挡,起到保护的作用。以下是一个简化的示例:

通常为了不暴露个人信息等敏感信息,会选用一个网关在前面对接,起到保护作用。例如,配置网关9527,作为网关使用,需要和其他应用一样,注册到Eureka。

附上工作示意图:+-----------------+ +-----------------+ +-----------------+| 应用服务1 | --> | 网关9527 | --> | 应用服务2 |+-----------------+ +-----------------+ +-----------------+图示说明:- 应用服务1和2通过网关9527进行通信。- 网关9527作为入口,对请求进行路由和过滤,保护内部应用服务。

一般为了不暴露自己的端口信息等,会选择架构一个网关在前面进行阻挡,起到保护的作用。附上一张工作示列图。

1.配置网关9527

gateway作为网关需要和其他的应用一样需要注册进eureka中进行管理,先创建应用gateway9527

pom文件,关键是gateway依赖

<dependencies> <dependency> <groupId>com.bai</groupId> <artifactId>cloud-api-common</artifactId> <version>${project.version}</version> </dependency> <!--gateway--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> <!--eureka client--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <!--热部署--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>

yml文件配置

server: port: 9527 spring: application: name: cloud-gateway cloud: gateway: discovery: locator: enabled: true # 开启从注册中心动态创建路由的功能,利用微服务名称进行路由 routes: - id: payment_route # 路由的id,没有规定规则但要求唯一,建议配合服务名 #匹配后提供服务的路由地址 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/get/** # 断言,路径相匹配的进行路由 - id: payment_route2 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/sp/** #断言,路径相匹配的进行路由 eureka: instance: hostname: cloud-gateway-service client: fetch-registry: true register-with-eureka: true service-url: defaultZone: eureka7001.com:7001/eureka/

主启动类正常配置

@SpringBootApplication @EnableEurekaClient public class GateWay9527 { public static void main(String[] args) { SpringApplication.run(GateWay9527.class,args); } }

2.配置路由两种方式

1)yml文件格式(推荐)

spring: application: name: cloud-gateway cloud: gateway: discovery: locator: enabled: true # 开启从注册中心动态创建路由的功能,利用微服务名称进行路由 routes: - id: payment_route # 路由的id,没有规定规则但要求唯一,建议配合服务名 #匹配后提供服务的路由地址 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/get/** # 断言,路径相匹配的进行路由 - id: payment_route2 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/sp/** #断言,路径相匹配的进行路由 - After=2020-11-09T11:09:52.794+08:00[Asia/Shanghai] - Cookie=username,bai #带Cookie,并且username的值为bai # - Header=X-Request-Id,\d+ #请求头要有 X-Request-Id属性并且值为整数的正则表达式

2)通过config配置类实现

@Configuration public class RouteConfig { @Bean public RouteLocator customerRoute(RouteLocatorBuilder builder){ RouteLocatorBuilder.Builder routes = builder.routes(); routes.route("payment_route1", r -> r.path("/guonei").uri("news.baidu.com/guonei")).build(); return routes.build(); } @Bean public RouteLocator bokeRoute(RouteLocatorBuilder builder){ RouteLocatorBuilder.Builder routes = builder.routes(); routes.route("payment_route2",r->r.path("/boke").uri("www.cnblogs.com/lin530/")).build(); return routes.build(); } }

3.断言(Predicate)

相当于多种限制,只有通过验证才能够访问到对应的方法

- id: payment_route2 #uri: localhost:8001 uri: lb://cloud-payment-service predicates: - Path=/payment/sp/** #断言,路径相匹配的进行路由 - After=2020-11-09T11:09:52.794+08:00[Asia/Shanghai] - Cookie=username,bai #带Cookie,并且username的值为bai # - Header=X-Request-Id,\d+ #请求头要有 X-Request-Id属性并且值为整数的正则表达式

不同的方法可以配置不同的断言,此处的断言需要满足路径对,after时间后,cookie带上正确的用户名才可以访问到,用cmd测试

Springcloud Gateway配置步骤图解如何绘制?

其他还有很多断言,请对照文档自行研究

4)过滤(filter)

对访问加上限制,通过验证才可以访问

新建过滤配置类

@Component @Slf4j public class GatewayGlobalFilter implements GlobalFilter, Ordered { @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { log.info("***time is :"+new Date()); String uname = exchange.getRequest().getQueryParams().getFirst("uname"); if(uname==null){ log.info("没有用户名,出现错误:o(╥﹏╥)o"); exchange.getResponse().setStatusCode(HttpStatus.NOT_ACCEPTABLE); return exchange.getResponse().setComplete(); } return chain.filter(exchange); } /* 设置过滤器优先级,越小优先级越大 */ @Override public int getOrder() { return 0; } }

访问方式带上参数,

本篇所有代码均在GitHub:

github.com/MaTsukun/springcloud2020

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。