dubbox增加过滤器功能(附代码)

在开发中,有时候需要限制访问的权限,黑名单就是一种方法。对于Java Web应用,Spring的拦截器可以拦截Web接口的调用;而对于dubbo接口,Spring的拦截器就不管用了。
dubbo提供了Filter扩展,可以通过自定义Filter来实现这个功能。本文通过一个事例来演示如何实现dubbo接口的IP黑名单。

package com.alibaba.dubbo.demo;

import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.alibaba.dubbo.rpc.Filter;
import com.alibaba.dubbo.rpc.Invocation;
import com.alibaba.dubbo.rpc.Invoker;
import com.alibaba.dubbo.rpc.Result;
import com.alibaba.dubbo.rpc.RpcContext;
import com.alibaba.dubbo.rpc.RpcException;
import com.alibaba.dubbo.rpc.RpcResult;

public class AuthorityFilter implements Filter {
private static final Logger LOGGER = LoggerFactory.getLogger(AuthorityFilter.class);

private IpBlackList ipBlackList=new IpBlackList();

//dubbo通过setter方式自动注入
public void setIpWhiteList(IpBlackList ipWhiteList) {
this.ipBlackList = ipWhiteList;
}

@Override
public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
if (!ipBlackList.isEnabled()) {
LOGGER.debug("黑名单禁用");
return invoker.invoke(invocation);
}

String clientIp = RpcContext.getContext().getRemoteAddressString();
LOGGER.debug("访问ip为{}", clientIp);
List<String> allowedIps = ipBlackList.getAllowedIp();
if (!allowedIps.contains(clientIp)) {
return invoker.invoke(invocation);
} else {
return new RpcResult();
}
}
}


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

2配置文件
参考:调用拦截扩展
在resources目录下添加纯文本文件META-INF/dubbo/com.alibaba.dubbo.rpc.Filter,内容如下:
[plain] view plain copy
[color=red]xxxFilter=com.xxx.AuthorityFilter [/color]
修改dubbo的provider配置文件,在dubbo:provider中添加配置的filter,如下:
[html] view plain copy
[color=red]<dubbo:provider filter="xxxFilter" /> [/color]

这样就可以实现dubbo接口的IP黑名单功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值