我的地盘我做主! 博客:http://tester2test.cnblogs.com/   msn:win_soft@163.com

局域网内如何防止ARP欺骗

上一篇 / 下一篇  2007-01-24 11:39:37 / 个人分类:性能测试

局域网内如何防止ARP欺骗

作者:IHH    出处:赛迪网开发者论坛51Testing软件测试网\%ea/Z|Z_

对于ARP欺骗,提出几点加强安全防范的措施。环境是主机或者网关是基于Linux/BSD的。
%C X C2u,h8j6I0
TW-b FH0一、理论前提 51Testing软件测试网 y6\z-o%F!Z
51Testing软件测试网 A(gN$U3Fg-N$t
本着“不冤枉好人,不放过一个坏人的原则”,先说说我的一些想法和理论依据。首先,大家肯定发送ARP欺骗包肯定是一个恶毒的程序自动发送的,正常的TCP/IP网络是不会有这样的错误包发送的。
B6{#XKQII8]#mY0
Z+q m/rZ'M;A2[0这就假设,如果犯罪嫌疑人没有启动这个破坏程序的时候,网络环境是正常的,或者说网络的ARP 环境是正常的,如果我们能在犯罪嫌疑人启动这个犯罪程序的第一时间,一开始就发现了他的犯罪活动,那么就是人赃俱在,不可抵赖了,因为刚才提到,前面网络正常的时候证据是可信和可依靠的。好,接下来我们谈论如何在第一时间发现他的犯罪活动。 51Testing软件测试网$nx I]x

:H"kK0{Bt6wQ0ARP欺骗的原理如下:
N W)v@LP051Testing软件测试网:Ad?~8ncU
假设这样一个网络,一个Hub接了3台机器 51Testing软件测试网` k/r*KT7S
51Testing软件测试网Jde? pQ:vx
HostA HostB HostC 其中
-E!V5ZRM0
(Rvaq,waYW,g4I0A的地址为:IP:192.168.10.1 MAC: AA-AA-AA-AA-AA-AA 51Testing软件测试网|.HC%w%PDG}-{._
51Testing软件测试网.B ta(q|$z
B的地址为:IP:192.168.10.2 MAC: BB-BB-BB-BB-BB-BB
SX0g;\g|051Testing软件测试网;q@[(p;t~2F"txH
C的地址为:IP:192.168.10.3 MAC: CC-CC-CC-CC-CC-CC 51Testing软件测试网BuV1n@%k9_*l#Q
51Testing软件测试网 J#Ndc K_]5RN~a,i[
正常情况下 C:arp -a
pl|0CG Ye(L051Testing软件测试网#b.a]OZJXV
Interface: 192.168.10.1 on Interface 0x1000003 51Testing软件测试网M fDB-H.o W#q;gX\

2N7u].c'f7_7IR8~;BB(H*H0Internet Address Physical Address Type 51Testing软件测试网y:h'bR1yFM&S

3X,Bs m8lq0192.168.10.3 CC-CC-CC-CC-CC-CC dynamic
9h M2j b%qP p2X0
+c:x4`*L;rZ!U0现在假设HostB开始了罪恶的ARP欺骗:
0UR_T t6Z|#a051Testing软件测试网9kp*l z \&Y
B向A发送一个自己伪造的ARP应答,而这个应答中的数据为发送方IP地址是192.168.10.3(C的IP地址),MAC地址是DD-DD-DD-DD-DD-DD(C的MAC地址本来应该是CC-CC-CC-CC-CC-CC,这里被伪造了)。当A接收到B伪造的ARP应答,就会更新本地的ARP缓存(A可不知道被伪造了)。而且A不知道其实是从B发送过来的,A这里只有192.168.10.3(C的IP地址)和无效的DD-DD-DD-DD-DD-DD mac地址,没有和犯罪分子B相关的证据,哈哈,这样犯罪分子岂不乐死了。
JJ-}#z5} S8B S051Testing软件测试网hO0B)J*RU
现在A机器的ARP缓存更新了:
H-Sn p]]051Testing软件测试网6S*y)T$WW-M5L4o

^)hMhA1yA#cB Y0
C:>arp -a
            Interface: 192.168.10.1 on Interface 0x1000003
            Internet Address Physical Address Type
            192.168.10.3 DD-DD-DD-DD-DD-DD dynamic

51Testing软件测试网ylEza2m%X

Vp6V*G;?p;f1f2~0这可不是小事。局域网的网络流通可不是根据IP地址进行,而是按照MAC地址进行传输。现在192.168.10.3的MAC地址在A上被改变成一个本不存在的MAC地址。现在A开始Ping 192.168.10.3,网卡递交的MAC地址是DD-DD-DD-DD-DD-DD,结果是什么呢?网络不通,A根本不能Ping通C!
7b.C^!ZDm j4JZX+b051Testing软件测试网l-Y9E3xVJ n$`0\N
所以,局域网中一台机器,反复向其他机器,特别是向网关,发送这样无效假冒的ARP应答信息包,NND,严重的网络堵塞就开始了!网吧管理员的噩梦开始了。我的目标和任务,就是第一时间,抓住他。 51Testing软件测试网oZ v_R5Bd&l$Z

51Testing软件测试网6^+},C2IdyU

不过从刚才的表述好像犯罪分子完美的利用了以太网的缺陷,掩盖了自己的罪行。但其实,以上方法也有留下了蛛丝马迹。尽管,ARP数据包没有留下HostB的地址,但是,承载这个ARP包的ethernet帧却包含了HostB的源地址。
,{4@:Q5U%V8cM9q'I0
hh[,N Iz(FX c5U0而且,正常情况下ethernet数据帧中,帧头中的MAC源地址/目标地址应该和帧数据包中ARP信息配对,这样的ARP包才算是正确的。如果不正确,肯定是假冒的包,可以提醒!但如果匹配的话,也不一定代表正确,说不定伪造者也考虑到了这一步,而伪造出符合格式要求,但内容假冒的ARP数据包。
b"i%h4zQzw Dd,kO0
G5_UW:t/D#t ~8v-O0不过这样也没关系,只要网关这里拥有本网段所有MAC地址的网卡数据库,如果和Mac数据库中数据不匹配也是假冒的ARP数据包。也能提醒犯罪分子动手了。 51Testing软件测试网3B Wf#yJ(s
51Testing软件测试网2@]6vGDf AE
二、防范措施 51Testing软件测试网q-fEn-y1Z+g

e D,wX'k#Y!z'w01.建立DHCP服务器(建议建在网关上,因为DHCP不占用多少CPU,而且ARP欺骗攻击一般总是先攻击网关,我们就是要让他先攻击网关,因为网关这里有监控程序的,网关地址建议选择192.168.10.2,把192.168.10.1留空,如果犯罪程序愚蠢的话让他去攻击空地址吧),另外所有客户机的IP地址及其相关主机信息,只能由网关这里取得,网关这里开通DHCP服务,但是要给每个网卡,绑定固定唯一IP地址。 51Testing软件测试网5f}VQ/~.j'k x?z
51Testing软件测试网/r0]oaXF {
一定要保持网内的机器IP/MAC一一对应的关系。这样客户机虽然是DHCP取地址,但每次开机的IP地址都是一样的。
!pJ[pK,bza*Pm051Testing软件测试网r c,Y)i)j
2.建立MAC数据库,把网吧内所有网卡的MAC地址记录下来,每个MAC和IP、地理位置统统装入数据库,以便及时查询备案。
\mC_.gNE051Testing软件测试网\Df Q2k4f
3.网关机器关闭ARP动态刷新的过程,使用静态路邮,这样的话,即使犯罪嫌疑人使用ARP欺骗攻击网关的话,这样对网关也是没有用的,确保主机安全。
mJ]q2r,t051Testing软件测试网 F[_,ATkK-A1j ^
网关建立静态IP/MAC捆绑的方法是:建立/etc/ethers文件,其中包含正确的IP/MAC对应关系,格式如下:
ehvF u(w-I_o051Testing软件测试网"U_ vfee2y!o
192.168.2.32 08:00:4E:B0:24:47 51Testing软件测试网.]PGd+tKRu
51Testing软件测试网;JH6dWHf.O\sF
然后再/etc/rc.d/rc.local最后添加:
7Mkgt{0r051Testing软件测试网4O8P?2h!}Jj
arp -f 生效即可
&H*X8M$W-e051Testing软件测试网ov'S&Sr3j
4.网关监听网络安全。网关上面使用TCPDUMP程序截取每个ARP程序包,弄一个脚本分析软件分析这些ARP协议。ARP欺骗攻击的包一般有以下两个特点,满足之一可视为攻击包报警:第一以太网数据包头的源地址、目标地址和ARP数据包的协议地址不匹配。
$U&f_ vh5fh0
wm p:aED0或者,ARP数据包的发送和目标地址不在自己网络网卡MAC数据库内,或者与自己网络MAC数据库 MAC/IP不匹配。这些统统第一时间报警,查这些数据包(以太网数据包)的源地址(也有可能伪造),就大致知道那台机器在发起攻击了。
!xDa9I4uT9` V#Jrb0
+L0C5I fGD `"g05.偷偷摸摸的走到那台机器,看看使用人是否故意,还是被任放了什么木马程序陷害的。如果后者,不声不响的找个借口支开他,拔掉网线(不关机,特别要看看Win98里的计划任务),看看机器的当前使用记录和运行情况,确定是否是在攻击。

)U2WWrg_|7WN%xM0
'C-P H;U2?},[]R0
"~ K$x Blh5k0
测试者家园 2007-01-16 08:48 发表评论
51Testing软件测试网 _ [S(n5Y:\+r+o

,mBr `/O0Link URL: http://www.cnblogs.com/tester2test/archive/2007/01/16/621322.html

TAG:

 

评分:0

我来说两句

Open Toolbar