geteway我的一些记录

geteway路由规则 

1.匹配到了以后,就会变成如果本地网关的端口为8099,请求地址为http://localhost:8099/xxxx,然后转发到 http://localhost:7070/xxxx

动态获取URL 

1.注册到注册中心去

2.url写成服务名称,不写成固定的url

多服务配置 

服务名称转发 

网关过滤器-路径过滤器 -重写请求规则

1.真正的请求地址不暴露出来,通过网关改写请求的路径,防止被恶意破坏

网关过滤器-路径过滤器-添加指令前缀 

1.在请求前前面拼一段前缀

 网关过滤器-路径过滤器-分割前缀

1.请求过来后删除前面几个前缀

网关过滤器-路径过滤器-获取参数后,将参数重新拼接到新的URL上面

网关过滤器-参数过滤器

网关过滤器-状态过滤器-setstatus

 

 当官方的网关过滤器不满足实际的时候,可以使用自定义的网关过滤器

 全局过滤器

1.系统自带的过滤器,不用修改,但是可以自定义

 

自定义全局过滤器-使用

1.会作用在全局的过滤器上面

2.@Component注册为全局组件,就会执行

 自定义全局过滤器-统一鉴权

自定义全局过滤器需要实现GlobalFilter和Ordered接口。
在filter方法中完成过滤器的逻辑判断处理
在getOrder方法指定此过滤器的优先级,返回值越大级别越低
ServerWebExchange 就相当于当前请求和响应的上下文,存放着重要的请求-响应属性、请求实 例和响应实例等等。一个请求中的request,response都可以通过 ServerWebExchange 获取
调用 chain.filter 继续向下游执行

1.判断用户是否有token


 

 
/**
 * 自定义一个全局过滤器
 *         实现globalfilter,ordered接口
 */
@Component
public class LoginFilter implements GlobalFilter, Ordered {
 
    /**
     * 执行过滤器中的过滤逻辑
     * @param exchange
     * @param chain
     * @return
     */
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String token = exchange.getRequest().getQueryParams().getFirst("access-token");
        if (token == null){
            //如果为null,认证失败
            System.out.println("没有登录");
            exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
            return exchange.getResponse().setComplete();
        }
        System.out.println("触发了全局过滤器!");
        return chain.filter(exchange);
    }
 
    /**
     * 指定过滤器执行顺序,返回值越小,执行优先级越高
     * @return
     */
    @Override
    public int getOrder() {
        return 0;
    }
}

 

 

限流 +Sentinel(根据这个视频进行配置)

163-SpringCloudGateway整合Sentinel实现限流_哔哩哔哩_bilibili

具体文件在百度云盘里

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud Gateway是一个基于Spring Cloud的微服务网关,它提供了一系列过滤器、路由和负载均衡等功能,可以用于构建分布式系统中的API网关。 要记录缓存请求的body和form表单,可以通过自定义过滤器来实现。首先,需要创建一个实现了GatewayFilterOrdered接口的自定义过滤器类。在这个过滤器中,可以获取到请求的body和form表单,并将其缓存起来。 下面是一个简单的实现示例: ```java import org.springframework.cloud.gateway.filter.GatewayFilter; import org.springframework.cloud.gateway.filter.GatewayFilterChain; import org.springframework.core.Ordered; import org.springframework.stereotype.Component; import org.springframework.web.server.ServerWebExchange; import reactor.core.publisher.Mono; @Component public class RequestLoggingFilter implements GatewayFilter, Ordered { private static final String CACHE_REQUEST_BODY_OBJECT_KEY = "cachedRequestBodyObject"; @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { // 获取请求的body和form表单 String body = exchange.getAttribute(CACHE_REQUEST_BODY_OBJECT_KEY); String form = exchange.getRequest().getHeaders().getFirst("Content-Type"); // TODO: 在这里记录缓存body和form表单 return chain.filter(exchange); } @Override public int getOrder() { return Ordered.LOWEST_PRECEDENCE; } } ``` 在这个过滤器中,我们通过`exchange.getAttribute(CACHE_REQUEST_BODY_OBJECT_KEY)`方法获取到了请求的body,并通过`exchange.getRequest().getHeaders().getFirst("Content-Type")`方法获取到了请求的form表单。 接下来,可以在`filter`方法中实现对缓存的记录逻辑,比如将body和form表单保存到数据库或日志中。 最后,将自定义的过滤器类添加到Spring Cloud Gateway的路由中,以便生效。 以上是一个简单的示例,实际情况可能会更复杂,需要根据具体的业务需求进行适当的调整和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值