微服务网关 gateway

使用手册:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/

1,gateway作用

1,统一入口
2,过滤请求
3,负载均衡

2,工作图示

微服务网关 gateway_第1张图片

3,操作步骤

1,引入依赖


  <dependency>
     <groupId>org.springframework.cloudgroupId>
      <artifactId>spring-cloud-starter-gatewayartifactId>
  dependency>
  <dependency>
      <groupId>com.alibaba.cloudgroupId>
      <artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
  dependency>
  <dependency>
      <groupId>com.alibaba.cloudgroupId>
      <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
  dependency>
  

2,配置文件


server:
  port: 19000
  
spring:
  application:
    name: gateway			//服务名
  profiles: local-dev		//环境,local-dev代表使用本地的yml配置文件,nacos-dev代表使用nacos上的配置文件
  cloud:
    gateway:
      enabled: true
      discovery:
        locator:
          lower-case-service-id: true
      routes:
        - id: base        	//路由唯一标识
          uri: lb://base   	//路由目标,HTTP表示固定地址,lb代表负载均衡
          predicates:		//断言,判断路由规则
            - Path=/base/**
          filters:			//路由过滤器,对请求做出处理
            - StripPrefix=1


# 忽略认证的路由
secure:
  ignore:
    uris:
      #- /**

4,基础配置

1,路由断言工厂

如下:此路由匹配 2017 年 1 月 20 日 17:42 山地时间(丹佛)之后提出的任何请求。
微服务网关 gateway_第2张图片

2,过滤器

微服务网关 gateway_第3张图片

2.1,路由过滤器 filters

给所有进入网关且符合路由规则uri( https://example.org )的请求添加一个请求头,

key为 X-Request-red

value为 blue
微服务网关 gateway_第4张图片

在服务中通过注解 @RequestHeader 来接收 blue 数值
在这里插入图片描述
2.2,默认过滤 default-filters:

对所有符合路由规则的请求过滤
微服务网关 gateway_第5张图片
如果要给响应结果添加多个响应头

在这里插入图片描述
如图
微服务网关 gateway_第6张图片

2.3,全局过滤 Global Filters

对所有路由都生效,且可自定义处理逻辑

步骤:

实现GlobalFilter接口

添加@Order()注解

编写处理逻辑


import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.annotation.Order;
import org.springframework.http.HttpStatus;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.stereotype.Component;
import org.springframework.util.MultiValueMap;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;

@Component
@Order(1)
public class AuthorizeFilter implements GlobalFilter {

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain){
//        1, 获取请求参数
        ServerHttpRequest request=exchange.getRequest();
//        2,获取参数
        MultiValueMap<String, String> param= request.getQueryParams();
        String auth=param.getFirst("Authorization");
//        3,验证参数值
        if ("admin".equals(auth)){
//        4,是,放行
            return chain.filter(exchange);
        }
//        5,否,拦截,并设置状态码
        exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
        return exchange.getResponse().setComplete();
    }
    
}


结论:
微服务网关 gateway_第7张图片

3,网关跨域 CORS Configuration

微服务网关 gateway_第8张图片


spring:
  cloud:
    gateway:
      globalcors: # 全局跨域
        add-to-simple-url-handler-mapping: true # 解决option请求被拦截问题
        cors-configurations:
          '[/**]':
            allowedOrigins: "https://docs.spring.io"  # 允许哪些网站的跨域请求
            allowedMethods:   # 允许跨域ajax的请求方式
              - GET
              - POST
            maxage: 10000 # 跨域检测的有效期
            allowedHeaders: "*" #允许在请求中携带头信息
            allowCredentials: true #允许携带cookie 
            

你可能感兴趣的:(Java,微服务,gateway,spring,cloud)