springcloud之网关zuul学习笔记

本文介绍如何使用Zuul实现服务路由及过滤功能,包括配置路由规则、禁用直连访问、设置统一访问前缀等内容,并演示了一个简单的安全验证过滤器实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

是什么?
在这里插入图片描述
能干吗?
路由和网关

开始

新建工程导入jar

在这里插入图片描述

配置yml

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
禁用不通过zuul的访问方式,我们的目的时要想访问先经过zuul,而不能直接访问。真是开发这里配置的*,表示禁止所有,具体看下一张图
在这里插入图片描述
在这里插入图片描述
加一个访问的统一前缀
在这里插入图片描述
其中在代码里面出现的“mydept”是一个逻辑名称,该名称的主要作用是将 path 与 serviceId 绑定在一起。(我的理解是,自己取得名字不重要,重要的是这个名字点了path和serviceId,该名称的主要作用是将 path 与 serviceId 绑定在一起,就相当于下面的api-a和api-b)
在这里插入图片描述
下图方志朋的写法:

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
  port: 8769
spring:
  application:
    name: service-zuul
zuul:
  routes:
    api-a:
      path: /api-a/**
      serviceId: service-ribbon
    api-b:
      path: /api-b/**
      serviceId: service-feign

启动类添加注解

在这里插入图片描述
在这里插入图片描述
下面比较启用路由和未启用路由的地址对比在这里插入图片描述

四、服务过滤

zuul不仅只是路由,并且还能过滤,做一些安全验证。继续改造工程;

@Component
public class MyFilter extends ZuulFilter{

    private static Logger log = LoggerFactory.getLogger(MyFilter.class);
    @Override
    public String filterType() {
        return "pre";
    }

    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() {
        RequestContext ctx = RequestContext.getCurrentContext();
        HttpServletRequest request = ctx.getRequest();
        log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));
        Object accessToken = request.getParameter("token");
        if(accessToken == null) {
            log.warn("token is empty");
            ctx.setSendZuulResponse(false);
            ctx.setResponseStatusCode(401);
            try {
                ctx.getResponse().getWriter().write("token is empty");
            }catch (Exception e){}

            return null;
        }
        log.info("ok");
        return null;
    }
}

filterType:返回一个字符串代表过滤器的类型,在zuul中定义了四种不同生命周期的过滤器类型,具体如下:
pre:路由之前
routing:路由之时
post: 路由之后
error:发送错误调用
filterOrder:过滤的顺序
shouldFilter:这里可以写逻辑判断,是否要过滤,本文true,永远过滤。
run:过滤器的具体逻辑。可用很复杂,包括查sql,nosql去判断该请求到底有没有权限访问。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值