微服务背景下,一个web应用都可能不再service依赖,而是通过RPC调用远端服务器上的服务。这些服务里,就包括了一些不能轻易暴露的后台功能接口。暴露出去的dubbo接口注册到某一个zk上后,该dubbo接口对注册到该zk上的消费者都是可见的。对公司内部而言,通常不会有人蓄意去调用一些敏感的接口,但也存在人为误用的可能呀。为此,考虑通过白名单机制来控制dubbo接口的访问。

现在以许可ip127.0.0.1访问接口fundRecordTemplateFacade为例演示。

扩展Filter

首先,我们需要实现com.alibaba.dubbo.rpc.Filter接口:

@Activate(group = { Constants.CONSUMER, Constants.PROVIDER })
public class FacadeAccessFilter implements Filter { private FacadeAccessConfig facadeAccessConfig; public FacadeAccessConfig getFacadeAccessConfig() { return facadeAccessConfig; } // 通过setter方式注入白名单配置文件 public void setFacadeAccessConfig(FacadeAccessConfig facadeAccessConfig) { this.facadeAccessConfig = facadeAccessConfig; } @Override public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException { Result result = null; // 获取调用的接口名 String reqFacade = invoker.getInterface().getSimpleName(); try { // 尝试在白名单配置文件里查找定义的接口,如果找不到则catch住异常、并许可访问。 Method method; try { method = facadeAccessConfig.getClass().getDeclaredMethod(editMethodName(reqFacade)); } catch (NoSuchMethodException e) { // 无特殊限制,则许可访问 result = invoker.invoke(invocation); return result; } // 走到这里,说明白名单配置文件配了对该facade的访问限制 // 获取remoteAddress:进行访问的应用,格式ip:port String remoteAddress = RpcContext.getContext().getRemoteAddressString(); // 只取ip String remoteIp = remoteAddress.split(":")[0]; // 获取licensinedApplications:许可的应用列表 String licensinedApplications = (String) method.invoke(facadeAccessConfig); if (StringUtils.isNotEmpty(licensinedApplications) && StringUtils.isNotEmpty(remoteIp) && licensinedApplications.contains(remoteIp)) { // 权限许可、进行访问 Help.log_info(getClass(), " remoteAddress" + remoteAddress + "访问接口" + reqFacade); result = invoker.invoke(invocation); return result; } else { // 权限不许可、退出访问 Help.log_info(getClass(), " remoteAddress" + remoteAddress + "无权访问接口" + reqFacade); result = new RpcResult("remoteAddress" + remoteAddress + "无权访问接口" + reqFacade); return result; } } catch (SecurityException e) { Help.log_error(getClass(), "校验remoteAddress是否有权限访问" + reqFacade + "发生异常", e); } catch (IllegalAccessException e) { Help.log_error(getClass(), "校验remoteAddress是否有权限访问" + reqFacade + "发生异常", e); } catch (IllegalArgumentException e) { Help.log_error(getClass(), "校验remoteAddress是否有权限访问" + reqFacade + "发生异常", e); } catch (InvocationTargetException e) { Help.log_error(getClass(), "校验remoteAddress是否有权限访问" + reqFacade + "发生异常", e); } return result; } private String editMethodName(String fieldName) { return "get" + fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1, fieldName.length()); } }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64

配置文件

  1. 在resources目录下添加纯文本文件META-INF/dubbo/com.alibaba.dubbo.rpc.Filter,内容如下: 

  2. 修改配置文件dubbo-common.xml,在dubbo:provider属性中添加配置的filter,内容如下: 

  3. 扩展Filter时,我们是通过setter方法将访问白名单FacadeAccessConfig注册到FacadeAccessFilter类中的,那么在配置文件(譬如:applicationContext.xml)里还需要对bean实例化。

    <!-- 将facade访问白名单注册到FacadeAccessFilter类中 --><bean id="facadeAccessFilter" class="com.roger.account.provider.filter.FacadeAccessFilter"> <property name="facadeAccessConfig" ref="facadeAccessConfig" /> </bean> <bean id="facadeAccessConfig" class="com.roger.account.provider.filter.FacadeAccessConfig" />
  • 1
  • 2
  • 3
  • 4
  • 5

访问白名单文件

我们看一下白名单文件的设计格式。本意希望能配置成”接口名=调用接口的应用名”,因为部署应用的ip变化可能性远高于应用本身的名称修改。但是在Invoker和Invocation对象中找不到客户端的应用名,无奈之下,就设计成了”接口名=调用接口的ip”。 

下面是FacadeAccessConfig类,定义的私有属性都是需要控制权限的dubbo接口名,getter方法从配置平台disconf上找到对应配置文件的对应属性值。

@Component(value = "facadeAccessConfig")
@DisconfFile(filename = "facadeAccessConfig.properties")
public class FacadeAccessConfig { // 定义可以访问fundRecordTemplateFacade的应用 private String fundRecordTemplateFacade; @DisconfFileItem(associateField = "fundRecordTemplateFacade", name = "fundRecordTemplateFacade") public String getFundRecordTemplateFacade() { return fundRecordTemplateFacade; } public void setFundRecordTemplateFacade(String fundRecordTemplateFacade) { this.fundRecordTemplateFacade = fundRecordTemplateFacade; } }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

这样,对于已经配置的一个接口,新增可访问的应用只需要添加ip。对于一个新配置的接口,只需要在配置文件facadeAccessConfig.properties里添加”接口名=调用接口的应用名”,然后在FacadeAccessConfig类中新增私有属性即可。

转载于:https://www.cnblogs.com/exmyth/p/8654959.html

dubbo接口访问控制相关推荐

  1. http和dubbo的区别_(转载)Dubbo 接口是什么? 与http 接口有什么区别

    面试的时候会被问到 除了http  https 请求外 有接触了解到其他的接口么? 一,什么是Dubbo 接口 Dubbo 接口是阿里巴巴开源的致力于提供高性能和透明化的RPC远程服务调用方案,以及S ...

  2. dubbo接口测试_Django测试工具平台之Dubbo接口请求 + 前端

    前言 本章内容主要完成以下几个内容: 1.记录Dubbo接口请求 2.搜索请求记录 3.前端页面完成 4.项目第一阶段展示 项目展示中主要演示在本地如何启动项目,进行调试.如果需要部署线上环境,可以去 ...

  3. 调用dubbo接口出现多次

    2019独角兽企业重金招聘Python工程师标准>>> 调用一次dubbo接口,断点在dubbo显示三次数据,网上发现dubbo的机制问题,https://blog.csdn.net ...

  4. Dubbo接口测试方法及步骤

    1)打开soapUI,点击File--New project: 2)右键New REST service from URL,注:因为dubbo接口不像http接口一样有URL,所以这里的URL可以随便 ...

  5. 使用CSE轻松实现接口访问控制

    本文介绍了如何使用CSE轻松实现接口访问控制,通过例子展现了CSE微服务开发框架在契约管理方面的优势. 在<基于CSE的微服务架构实践-基础架构>中,我们介绍了一个典型的微服务架构,如下图 ...

  6. python、java大作战,python测试dubbo接口

    很多小伙伴都反映公司要求测dubbo(dubbo是一个java的分布式开源框架)接口,不会写java代码,怎么测,能不能用python来调dubbo接口.当然是可以的了,最近研究了一下,很简单,分享给 ...

  7. java fastdfs 压测_利用jmeter+JAVA对RPC的单接口(dubbo接口等)进行性能测试,零基础(2)...

    建立JAVA项目 建立maven项目,加入Jmeter所需要的JAR包依赖. POM.xml  加入如下: org.apache.jmeter ApacheJMeter_core 3.2 org.ap ...

  8. 如何使用JMeter 对Dubbo接口进行测试

    1.Dubbo介绍 (1)Dubbo说明 Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案. 简单的说:Dubbo一个高性能的,基于 Java  ...

  9. dubbo接口统一异常处理的两种方式

    dubbo接口统一异常处理的两种方式 参考文章: (1)dubbo接口统一异常处理的两种方式 (2)https://www.cnblogs.com/zcz527/p/7655235.html 备忘一下 ...

最新文章

  1. Java 晋升必会的 70 道 「Spring 全家桶」高频面试题
  2. java反编译工具_漫话:如何给女朋友解释什么是编译与反编译
  3. camvid数据集使用方法_使用PyTorch处理CIFAR10数据集并显示
  4. 区块链需要用到mysql吗_区块链和传统数据库有什么区别?
  5. 前++和后++引发的血案
  6. 正则表达式收集(转)
  7. LINQ 实现多字段关联查询 C#
  8. android view
  9. en55032最新标准下载_欧盟新EMC标准EN55032强制实施
  10. 学习:java设计模式—Adapter模式
  11. FileUpload1文件上传
  12. navicat本地同步到navicat cloud
  13. Unity接入Android SDK
  14. 虚拟偶像主播的大致现状,数字人技术现状
  15. ET199加密方案——文件MD5校验
  16. SEO优化,外链重要还是友情链接重要?
  17. 【Git从入门到精通】02-深入Git
  18. 运算放大器的稳定性分析(一)
  19. 图像分析之曲率滤波(困惑篇)
  20. 图片局部无失真放大的两种方式

热门文章

  1. 《学习OpenCV3(中文版)》图书目录
  2. matlab 中的dir函数使用
  3. 系统架构设计师难吗?IT行业员工的最高荣耀是什么
  4. java代码混淆框架_Android常用框架混淆代码
  5. get request uni 参数_接口测试实战| GET/POST 请求区别详解
  6. 转发和重定向的区别是什么
  7. xshell远程连接自动断开的问题解决
  8. maven <skip></skip>属性
  9. @Mapper和@Repository的区别
  10. 059_arguments.callee和arguments.callee.caller