dubbo白名单通过filter,spring web通过拦截器或者filter即可

时间:2023-03-09 17:46:20
dubbo白名单通过filter,spring web通过拦截器或者filter即可

在开发中,有时候需要限制访问的权限,白名单就是一种方法。对于Java Web应用,Spring的拦截器可以拦截Web接口的调用;而对于dubbo接口,Spring的拦截器就不管用了。

dubbo提供了Filter扩展,可以通过自定义Filter来实现这个功能。本文通过一个事例来演示如何实现dubbo接口的IP白名单。

  1. 扩展Filter
    实现com.alibaba.dubbo.rpc.Filter接口:
    1. public class AuthorityFilter implements Filter {
    2. private static final Logger LOGGER = LoggerFactory.getLogger(AuthorityFilter.class);
    3. private IpWhiteList ipWhiteList;
    4. //dubbo通过setter方式自动注入
    5. public void setIpWhiteList(IpWhiteList ipWhiteList) {
    6. this.ipWhiteList = ipWhiteList;
    7. }
    8. @Override
    9. public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
    10. if (!ipWhiteList.isEnabled()) {
    11. LOGGER.debug("白名单禁用");
    12. return invoker.invoke(invocation);
    13. }
    14. String clientIp = RpcContext.getContext().getRemoteHost();
    15. LOGGER.debug("访问ip为{}", clientIp);
    16. List<String> allowedIps = ipWhiteList.getAllowedIps();
    17. if (allowedIps.contains(clientIp)) {
    18. return invoker.invoke(invocation);
    19. } else {
    20. return new RpcResult();
    21. }
    22. }
    23. }

    注意:只能通过setter方式来注入其他的bean,且不要标注注解!
    dubbo自己会对这些bean进行注入,不需要再标注@Resource让Spring注入,参见扩展点加载

  2. 配置文件
    参考:调用拦截扩展
    在resources目录下添加纯文本文件META-INF/dubbo/com.alibaba.dubbo.rpc.Filter,内容如下:
    1. xxxFilter=com.xxx.AuthorityFilter

    修改dubbo的provider配置文件,在dubbo:provider中添加配置的filter,如下:

    1. <dubbo:provider filter="xxxFilter" />

这样就可以实现dubbo接口的IP白名单功能了。