设为首页 收藏本站
查看: 444|回复: 0

[经验分享] Apache Mina 白名单实现方法

[复制链接]

尚未签到

发表于 2017-1-8 08:20:06 | 显示全部楼层 |阅读模式
  Mina自带了一个黑名单过滤器BlacklistFilter,可过滤黑名单列表中的网络连接。用来防止非法的客户端访问。
  但在某些应用场景里需要设定白名单,只接收某些指定IP的客户端发来的数据。这就需要实现白名单功能。
  我们可以自己实现白名单过滤器,方法很简单只需仿照BlacklistFilter做些修改即可。
  我自己写的WhiteFilter,代码如下:

/**
* Whitelist filter (based on Mina's Blacklist filter).
*/
public class WhitelistFilter extends IoFilterAdapter {
private final List<Subnet> whitelist = new CopyOnWriteArrayList<Subnet>();
private final static Logger LOGGER = LoggerFactory.getLogger(WhitelistFilter.class);
public void setWhitelist(InetAddress[] addresses) {
if (addresses == null) {
throw new NullPointerException("addresses");
}
whitelist.clear();
for (InetAddress addr : addresses) {
allow(addr);
}
}
public void setSubnetWhitelist(Subnet[] subnets) {
if (subnets == null) {
throw new NullPointerException("Subnets must not be null");
}
whitelist.clear();
for (Subnet subnet : subnets) {
allow(subnet);
}
}
public void setWhitelist(Iterable<InetAddress> addresses) {
if (addresses == null) {
throw new NullPointerException("addresses");
}
whitelist.clear();
for (InetAddress address : addresses) {
allow(address);
}
}
public void setSubnetWhitelist(Iterable<Subnet> subnets) {
if (subnets == null) {
throw new NullPointerException("Subnets must not be null");
}
whitelist.clear();
for (Subnet subnet : subnets) {
allow(subnet);
}
}
public void allow(InetAddress address) {
if (address == null) {
throw new NullPointerException("Adress to block can not be null");
}
allow(new Subnet(address, 32));
}
public void allow(Subnet subnet) {
if (subnet == null) {
throw new NullPointerException("Subnet can not be null");
}
whitelist.add(subnet);
}
public void disallow(InetAddress address) {
if (address == null) {
throw new NullPointerException("Adress to unblock can not be null");
}
disallow(new Subnet(address, 32));
}
public void disallow(Subnet subnet) {
if (subnet == null) {
throw new NullPointerException("Subnet can not be null");
}
whitelist.remove(subnet);
}
@Override
public void sessionCreated(NextFilter nextFilter, IoSession session) {
if (isAllowed(session)) {
nextFilter.sessionCreated(session);
} else {
blockSession(session);
}
}
@Override
public void sessionOpened(NextFilter nextFilter, IoSession session) throws Exception {
if (isAllowed(session)) {
nextFilter.sessionOpened(session);
} else {
blockSession(session);
}
}
@Override
public void sessionClosed(NextFilter nextFilter, IoSession session) throws Exception {
if (isAllowed(session)) {
nextFilter.sessionClosed(session);
} else {
blockSession(session);
}
}
@Override
public void sessionIdle(NextFilter nextFilter, IoSession session, IdleStatus status) throws Exception {
if (isAllowed(session)) {
nextFilter.sessionIdle(session, status);
} else {
blockSession(session);
}
}
@Override
public void messageReceived(NextFilter nextFilter, IoSession session, Object message) {
if (isAllowed(session)) {
nextFilter.messageReceived(session, message);
} else {
blockSession(session);
}
}
@Override
public void messageSent(NextFilter nextFilter, IoSession session, WriteRequest writeRequest) throws Exception {
if (isAllowed(session)) {
nextFilter.messageSent(session, writeRequest);
} else {
blockSession(session);
}
}
private void blockSession(IoSession session) {
LOGGER.warn("Remote address is not allowed; closing.");
session.close(true);
}
private boolean isAllowed(IoSession session) {
SocketAddress remoteAddress = session.getRemoteAddress();
if (remoteAddress instanceof InetSocketAddress) {
InetAddress address = ((InetSocketAddress) remoteAddress).getAddress();
// check all subnets
for (Subnet subnet : whitelist) {
if (subnet.inSubnet(address)) {
return true;
}
}
}
return false;
}
}


调用时要加入whitelist过滤器
IoAcceptor acceptor = new NioSocketAcceptor();
WhitelistFilter whitelistFilter=new WhitelistFilter();
InetAddress[] address= new InetAddress[1];
address[0]=InetAddress.getByName("192.168.136.123");
whitelistFilter.setWhitelist(address);
acceptor.getFilterChain().addFirst("white",whitelistFilter);
acceptor.getFilterChain().addLast("logger", new LoggingFilter());   
acceptor.getFilterChain().addLast("codec", new ProtocolCodecFilter(new TextLineCodecFactory(Charset.forName("GBK"))));     
acceptor.setHandler(new ServerHandler());     
acceptor.getSessionConfig().setReadBufferSize(2048);     
acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, 10);     
acceptor.bind(new InetSocketAddress(PORT));     


这样服务端只会从指定的IP接收数据,如果客户端使用其他的IP地址则服务端拒绝连接。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-325309-1-1.html 上篇帖子: apache缓存css,images,js文件 下篇帖子: apache Cxf和spring的结合
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表