gateway的学习

1.网关的作用

1.负载均衡

2.过滤器的使用

1.通过配置文件实现的过滤器

2.代码逻辑层面实现全局过滤器

java 复制代码
//全局过滤器代码逻辑实现
@Component
//@Order(1):注解配置过滤器的执行顺序
public class GlobalFilter implements GatewayFilter, Ordered {
    /**
     * 处理当前请求,有必要的话通过 {@link GatewayFilterChain} 将请求交给下一个过滤器处理
     *
     * @param exchange 请求上下文,里面可以获取 Request、Response 等信息
     * @param chain 用来把请求委托给下一个过滤器
     * @return {@code Mono<Void>} 返回值标示当前过滤器业务结束
     */

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        ServerHttpRequest request = exchange.getRequest();
        MultiValueMap<String, String> params = request.getQueryParams();
        String token = params.getFirst("token");
        if("token".equals(token)){
            //放行到下一个过滤器
            return chain.filter(exchange);
        }
        //401:登陆失败
        exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
        return exchange.getResponse().setComplete();
    }

    //代码配置过滤器顺序
    @Override
    public int getOrder() {
        return 1;
    }

}

3.过滤器的执行顺序

4.网关跨域处理

相关推荐
HIT_Weston5 分钟前
97、【Ubuntu】【Hugo】搭建私人博客:搜索功能(二)
linux·运维·ubuntu
chen_mangoo18 分钟前
HDMI简介
android·linux·驱动开发·单片机·嵌入式硬件
何达维30 分钟前
`kubectl top nodes` 或 `kubectl top pods` 返回 `metrics not available yet` 的排查、解决
linux
东皇太星1 小时前
linux 内存管理详解
linux·运维·服务器
JY.yuyu1 小时前
Linux计划任务进程
linux·运维·服务器
single-life1 小时前
Linux 下 部署es+nebula(附带内网部署方式)
linux·运维·elasticsearch·nebula
ICT董老师1 小时前
kubernetes中operator与helm有什么区别?部署mysql集群是选择operator部署还是helm chart部署?
linux·运维·mysql·云原生·容器·kubernetes
wjhx1 小时前
对ubuntu22.04版本日志的处理
linux·ubuntu
情缘晓梦.1 小时前
Linux指令和权限
linux·运维·服务器
ybdesire1 小时前
Joern服务器启动后cpgqls-client结合python编程进行扫描
运维·服务器·python