Gateway网关-全局过滤器

30 篇文章 0 订阅
20 篇文章 1 订阅
本文介绍了如何在Spring框架下实现全局过滤器GlobalFilter,通过AuthorizeFilter拦截并验证用户身份,实现对所有路由的访问控制。详细步骤包括创建实现类、添加顺序注解及测试验证。
摘要由CSDN通过智能技术生成

目录

一、全局过滤器 GlobalFilter

二、案例实现

2.1 创建AuthorizeFilter实现类 

2.2 重启服务测试

 三、总结

 3.1 全局过滤器的作用是什么?

 3.2 实现全局过滤器的步骤?


一、全局过滤器 GlobalFilter

全局过滤器的作用也是处理一切进入网关的请求和微服务响应,与GatewayFilter的作用一样。
区别在于GatewayFilter通过配置定义,处理逻辑是固定的。而GlobalFilter的逻辑需要自己写代码实现。
定义方式是实现GlobalFilter接口。

public interface GlobalFilter {
/**
* 处理当前请求,有必要的话通过{@link GatewayFilterChain}将请求交给下一个过滤器处理

*
* @param exchange 请求上下文,里面可以获取Request、Response等信息
* @param chain 用来把请求委托给下一个过滤器
* @return {@code Mono<Void>} 返回标示当前过滤器业务结束
*/
Mono<Void> filter(ServerWebExchange exchange,GatewayFilterChain chain) ;

}

二、案例实现

需求(定义全局过滤器,拦截并判断用户身份):

定义全局过滤器,拦截请求,判断请求的参数是否满足下面条件:

  • 参数中是否有authorization
  • authorization参数值是否为admin

如果同时满足则放行,否则拦截 

2.1 创建AuthorizeFilter实现类 
// ogder(int) 顺序注解,用于实现过滤器谁先执行的顺序,数值越小优先级越高,负数为最高
@ogder(-1)
// Component 注入到Spring当中 最为一个bean
@Component
public class AuthorizeFilter implements GlobalFilter {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
     // 1.获取请求参数
    ServerHttpRequest request = exchange.getRequestO;MultiValueMap<String,String> params =             request.getQueryParams();
    // 2.获取参数中的 authorization 参数
    String auth = params,getFirst( key: "authorization");
    // 3断参数值是否等于 admin
    if ("admin".equals(auth)){
        // 4.是,放行
        return chain.filter(exchange);
    }
    // 5.否,拦截
    // 5.1.设置状态码
    exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
    // 5.2.拦截请求
    return exchange.getResponse(0.setComplete();
    }
}
2.2 重启服务测试

 不加参数不可访问,证明过滤器已生效

加上请求参数后可以访问 

 三、总结

 3.1 全局过滤器的作用是什么?
  • 对所有路由都生效的过滤器,并且可以自定义处理逻辑
 3.2 实现全局过滤器的步骤?
  • 实现GlobalFilter接口
  • 添加@Order注解或实现Ordered接口
  • 编写处理逻辑
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值