微服务——统一网关Getway

为什么需要网关?

网关的两种实现:

网关Getway------快速入门

步骤一

网关背身也是一个微服务,需要注册到nacos中去

步骤二

成功运行后

可以通过网关进行请求转发到对应服务。

流程如下:

路由断言工厂

网关路由可以配置的东西有如下。

spring中的11中基本的Predicate工厂

路由过滤器GatewayFilter

案例:

在userserver中获取到请求头的要用一个@RequestHeader注解,required = false表示可传可不传

java 复制代码
    /**
     * 路径: /user/110
     *
     * @param id 用户id
     * @return 用户
     */
    @GetMapping("/{id}")
    public User queryById(@PathVariable("id") Long id,@RequestHeader(value = "Truth",required = false) String truth) {
        System.out.println(truth);
        return userService.queryById(id);
    }

全局过滤器GlobalFilter

案例2:

这里可以由两种方式设定过滤器顺序,注解和接口。

java 复制代码
@Component
//@Order(-1) //过滤器的优先级,越小越高
public class AuthorizeFilter implements GlobalFilter , Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        //1.获取请求参数
        ServerHttpRequest request = exchange.getRequest();
        MultiValueMap<String, String> queryParams = request.getQueryParams();
        //2.获取参数中的authorization参数
        String authorization = queryParams.getFirst("authorization");
        //3.判断参数值是否等于admin
        if("admin".equals(authorization)) {
            //4.是,放行
          return chain.filter(exchange);
        }
        //5.否,拦截
        //5.1设置状态码
        exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
        return exchange.getResponse().setComplete();
    }

    @Override
    public int getOrder() {
        return -1;
    }
}

运行结果符合预期所示

过滤器执行顺序

网关的cors跨域配置

options请求就是CORS的询问请求。

相关推荐
江团1io012 分钟前
微服务雪崩问题与系统性防御方案
微服务·云原生·架构
Yuki’36 分钟前
网络编程---UDP
c语言·网络·网络协议·udp
鲸屿19539 分钟前
python之socket网络编程
开发语言·网络·python
小毛驴8501 小时前
所有微服务部署都使用一个git地址,并且通过docker部署各个服务的情况下,如何编写mvn指令来处理各个服务。
git·docker·微服务
软件测试很重要1 小时前
UOS20系统安装与 SSH/XRDP 远程访问功能配置指南
linux·运维·ssh
天天年年天天。1 小时前
TCP/IP、HTTP 和 HTTPS简介
网络
对你无可奈何2 小时前
关于Ubuntu的 update造成的内核升级
运维·服务器·ubuntu
想睡hhh2 小时前
网络原理——传输层协议UDP
网络·网络协议·udp
qq_312920112 小时前
Nginx限流与防爬虫与安全配置方案
运维·爬虫·nginx·安全
GanGuaGua2 小时前
Linux系统:线程的互斥和安全
linux·运维·服务器·c语言·c++·安全