zoukankan      html  css  js  c++  java
  • Sentinel授权规则-实现网关授权

    授权规则可以对调用方的来源做控制,有白名单和黑名单两种方式。
    1.白名单:来源(origin)在白名单内的调用者允许访问
    2.黑名单:来源(origin)在黑名单内的调用者不允许访问

    例如,我们限定只允许从网关来的请求访问order-service,那么流控应用中就填写网关的名称

     

    Sentinel是通过RequestOriginParser这个接口的parseOrigin来获取请求的来源的。

    public interface RequestOriginParser {
        /**    
         * 从请求request对象中获取origin,获取方式自定义
         */
        String parseOrigin(HttpServletRequest request);
    }


    例如,在order-service服务中我们尝试从request中获取一个名为origin的请求头,作为origin的值:

    @Component
    public class HeaderOriginParser implements RequestOriginParser {
        @Override
        public String parseOrigin(HttpServletRequest request) {
            // 1.获取请求头
            String origin = request.getHeader("origin");
            // 2.非空判断
            if (StringUtils.isEmpty(origin)) {
                origin = "blank";
            }
            return origin;
        }
    }

     

    我们还需要在gateway服务中,利用网关的过滤器添加名为gateway的origin头:

    spring:
      application:
        name: gateway
      cloud:
        gateway:
          default-filters:
            - AddRequestHeader=Truth,Itcast is freaking awesome!
            - AddRequestHeader=origin,gateway

    给/order/{orderId} 配置授权规则:

     

    效果实例

    http://localhost:8088/order/103 ##服务直接访问拒绝
    {"msg": 没有权限访问, "status": 401}
    
    http://localhost:10010/order/103 ##网关访问直接通过
    {"id":103,"price":43900,"name":"骆驼(CAMEL)休闲运动鞋女","num":1,"userId":3,"user":{"id":null,"username":null,"address":null}}
  • 相关阅读:
    一个表对应另一个表中多个主键的查询方法(把一个表当成两个表用)
    可以切换数据库的SqlHelper
    win7安装后的用户选择
    如何删除 Windows.old 文件夹
    Windows Server 2008磁盘清理工具
    sqlserver express版PRIMARY 大小不能超过4G
    一交换机,一光猫、一路由器组internet网的方法
    公司部门职责清晰
    IIS下载EXE(拾遗)
    win2008 IIS 7.0中WebDAV
  • 原文地址:https://www.cnblogs.com/linjiqin/p/15375257.html
Copyright © 2011-2022 走看看