zoukankan      html  css  js  c++  java
  • dubbo白名单通过filter,spring web通过拦截器或者filter即可

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

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

    1. 扩展Filter
      实现com.alibaba.dubbo.rpc.Filter接口:
      [java] view plain copy
       
      1. public class AuthorityFilter implements Filter {  
      2.     private static final Logger LOGGER = LoggerFactory.getLogger(AuthorityFilter.class);  
      3.   
      4.     private IpWhiteList ipWhiteList;  
      5.   
      6.     //dubbo通过setter方式自动注入  
      7.     public void setIpWhiteList(IpWhiteList ipWhiteList) {  
      8.         this.ipWhiteList = ipWhiteList;  
      9.     }  
      10.   
      11.     @Override  
      12.     public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {  
      13.         if (!ipWhiteList.isEnabled()) {  
      14.             LOGGER.debug("白名单禁用");  
      15.             return invoker.invoke(invocation);  
      16.         }  
      17.   
      18.         String clientIp = RpcContext.getContext().getRemoteHost();  
      19.         LOGGER.debug("访问ip为{}", clientIp);  
      20.         List<String> allowedIps = ipWhiteList.getAllowedIps();  
      21.         if (allowedIps.contains(clientIp)) {  
      22.             return invoker.invoke(invocation);  
      23.         } else {  
      24.             return new RpcResult();  
      25.         }  
      26.     }  
      27. }  
      注意:只能通过setter方式来注入其他的bean,且不要标注注解!
      dubbo自己会对这些bean进行注入,不需要再标注@Resource让Spring注入,参见扩展点加载
    2. 配置文件
      参考:调用拦截扩展
      在resources目录下添加纯文本文件META-INF/dubbo/com.alibaba.dubbo.rpc.Filter,内容如下:
      [plain] view plain copy
       
      1. xxxFilter=com.xxx.AuthorityFilter  
      修改dubbo的provider配置文件,在dubbo:provider中添加配置的filter,如下:
      [html] view plain copy
       
      1. <dubbo:provider filter="xxxFilter" />  

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

  • 相关阅读:
    C/C++各种类型int、long、double、char表示范围(最大和最小)
    XSS学习笔记(五)-XSS防御
    组态Log4j(非常具体的)
    C#抽象类其中创建一个静态方法
    DirectSound应用
    谈论Hibernate级联删除——JPA根据Hibernate实现许多级联删除CascadeType.DELETE_ORPHAN
    failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found
    英语语法总结---一、英语中定语放在哪
    windows常用命令有哪些(整理)
    css如何实现垂直居中(5种方法)
  • 原文地址:https://www.cnblogs.com/panxuejun/p/8796890.html
Copyright © 2011-2022 走看看