Zuul 网关 令牌验证配置

在上一篇Feign的基础上进行配置

创建子项目——》Eureka Client + Zuul

配置文件,在此之前,服务消费者需要将接口暴露在注册中心,以便网关转发请求。还有需要设置zuul和hystrix的超时时间,否则服务降级处理将出现zuul超时错误。zuul路由规则参考文档

server:
  port: 9000 #服务端口
spring:
  application:
    name: zuul-gateway #指定服务名
###服务注册到eureka注册中心的地址
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8888/eureka/
    ###因为该应用为服务提供者,是eureka的一个客户端,需要注册到注册中心
    register-with-eureka: true
    ###是否需要从eureka上检索服务
    fetch-registry: true
zuul:
  routes: #定义服务转发规则
    ribbon-consumer: #名字尽量和业务系统相关
      path: /consumer-zuul/** #匹配consumer-zuul的请求consumer服务
      serviceid: ribbon-consumer
  host:
    connect-timeout-millis: 15000 #HTTP连接超时要比Hystrix的大
    socket-timeout-millis: 60000   #socket超时
## 设置ribbon的hystrix的超时时间
ribbon:
  ReadTimeout: 10000
  ConnectTimeout: 10000

在启动类上添加注解

@EnableZuulProxy
@ComponentScan(basePackages = {"com.wxl"})

创建认证逻辑类,没有添加认证请求头的请求将被视为非法请求,返回提示信息

@Component
public class TokenFilter extends ZuulFilter {
    @Override
    public String filterType() {
        return "pre"; // 在进入服务之前执行
    }

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

    @Override
    public boolean shouldFilter() {
        return true; // 返回true 代表这个过滤器需要执行
    }

    // 这里编写具体认证信息
    @Override
    public Object run() throws ZuulException {
        RequestContext requestContext = RequestContext.getCurrentContext();
        HttpServletRequest request = requestContext.getRequest();
        // 获取用户令牌
        String token = request.getHeader("Authorization");
        // 如果令牌为空则 返回错误信息
        if(StringUtils.isEmpty(token)){
            requestContext.setSendZuulResponse(false); // 过滤该请求,不对其进行路由
            requestContext.setResponseStatusCode(401); // 设置响应状态码
            requestContext.setResponseBody("No Permission!"); // 设置响应状态码
        }
        return null;
    }
}

启动网关,可以启动多个网关形成集群,由nginx进行负载(这里单节点测试)

没有携带请求头,返回No Permission!

携带请求头,返回服务返回消息

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值