25 zuul权限校验、接口限流

1,权限校验:


package com.taotao.steam.gateway.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import lombok.extern.slf4j.Slf4j;
import org.apache.logging.log4j.util.Strings;
import org.springframework.cloud.netflix.zuul.filters.support.FilterConstants;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;
/**
 * @author aping
 * @time 2020/5/3 11:28
 */
@Component
@Slf4j
public class TokenFilter  extends ZuulFilter {
    /**
     * 过滤类型 pre 表示在请求之前进行执行
     * @return
     */
    @Override
    public String filterType() {
        return "pre";
    }

    /**
     * 过滤器执行顺序 ,当一个请求在同一阶段的时候存在多个过滤器的时候,多个过滤器执行顺序
     * @return
     */
    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        //共享RequestContext,上下文对象
        RequestContext requestContext = RequestContext.getCurrentContext();
        HttpServletRequest request = requestContext.getRequest();

        System.out.println(request.getRequestURI());
        //需要权限校验URL
        if ("/swagger-ui.html/**".equalsIgnoreCase(request.getRequestURI())) {
            return true;
        } else if ("/api-aop/**".equalsIgnoreCase(request.getRequestURI())) {
            return true;
        }else if ("/api-backstage/**".equalsIgnoreCase(request.getRequestURI())) {
            return true;
        }else if ("/api-community/**".equalsIgnoreCase(request.getRequestURI())) {
            return true;
        }
        return  false;


    }

    /**
     * 编写业务逻辑代码
     * @return
     * @throws ZuulException
     */
    @Override
    public Object run() throws ZuulException {


        //获取所有的服务接口,判断服务是否有传递token
        //1获取上下文
        RequestContext currentcontext= RequestContext.getCurrentContext();
        //获取request
        HttpServletRequest request=currentcontext.getRequest();
        String token=request.getParameter("userToken");
        if(Strings.isBlank(token)){
            currentcontext.setSendZuulResponse(false);
            currentcontext.setResponseBody("token is null");
            currentcontext.setResponseStatusCode(401);
        }
        log.info("通过过滤");
        return null;

    }
}









2,接口限流:
集成guava

<!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>29.0-jre</version>
</dependency>



接口限流可以在nginx层面做限流,也可以在网关层面做限流,这里在网关层面做限流,基于guava框架来做网关限流。

先对guava框架限流的概念进行讲解下:


1090617-20180906213610239-526459252.png

的大致意思就是每一个请求进来先到桶里去拿令牌,拿到令牌的请求放行,假设你设置了1000个令牌,如果拿完了,那么后面来调接口的请求就需要排队等有新的令牌才能调用该接口。


package com.taotao.steam.gateway.filter;

import com.google.common.util.concurrent.RateLimiter;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

/**
* 接口限流
* @author aping
* @time 2020/5/3 16:02
*/
@Component
public class OrderRateLimiterFilter extends ZuulFilter {
  //每秒差生1000个令牌
  private  static  final RateLimiter RATE_LIMITER=RateLimiter.create(1);

  @Override
  public String filterType() {
      return "pre";
  }

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

  @Override
  public boolean shouldFilter() {
      RequestContext requestContext=RequestContext.getCurrentContext();
      HttpServletRequest request =requestContext.getRequest();
      //只对特定接口限流
      if("/api-aop/**".equals(request.getRequestURI())){
          return  true;
      }

      return false;
  }

  @Override
  public Object run() throws ZuulException {
      RequestContext requestContext=RequestContext.getCurrentContext();
      //相当于每调用一次tryAcquire()方法。令牌数量减去1,当1000个令牌用完后,后面的接口不能访问呢进来
      //当然这里只写类上面一个接口,可以这么写,实际可以在这里要加一层接口判断。
      if(!RATE_LIMITER.tryAcquire()){
          requestContext.setSendZuulResponse(false);
          //HttpStatus.TOO_MANY_REQUESTS.value()
          requestContext.setResponseStatusCode(HttpStatus.TOO_MANY_REQUESTS.value());
      }
      return null;
  }
}





©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352