zoukankan      html  css  js  c++  java
  • 转一篇:arp欺骗的原理和防御

    ARP欺骗的原理和防御


    来源:天佑网络安全小组  作者:linzi


      局域网内有人使用ARP欺骗的木马程序(比如:传奇盗号的软件,比较流行的叫网络执行官的管理软件,某些恶意策程序也被加载了此程序)。 

      要了解故障原理,我们先来了解一下ARP协议。 

      在局域网中,通过ARP协议来完成IP地址转换为第二层物理地址(即MAC地址)的。ARP协议对网络安全具有重要的意义。通过伪造IP地址和MAC地址实现ARP欺骗,能够在网络中产生大量的ARP通信量使网络阻塞。 

      ARP协议是“Address Resolution Protocol”(地址解析协议)的缩写。在局域网中,网络中实际传输的是“帧”,帧里面是有目标主机的MAC地址的。在以太网中,一个主机要和另一个主机进行直接通信,必须要知道目标主机的MAC地址。但这个目标MAC地址是如何获得的呢?它就是通过地址解析协议获得的。所谓“地址解析”就是主机在发送帧前将目标IP地址转换成目标MAC地址的过程。ARP协议的基本功能就是通过目标设备的IP地址,查询目标设备的MAC地址,以保证通信的顺利进行。

    在命令行中使用arp -a命令,获得本机的ARP缓存.如果想知道一个局域网主机的MAC地址,可以先Ping它,然后再使用这个命令. 以下是我去获得非飞的主机的MAC地址的过程.获得本机的MAC可以用ipconfig/all获得. 


    C:\Documents and Settings\Administrator>ping feifei

    Pinging feifei[10.1.28.23] with 32 bytes of data:

    Reply from 10.1.28.23: bytes=32 time=1ms TTL=128
    Reply from 10.1.28.23: bytes=32 time<1ms TTL=128
    Reply from 10.1.28.23: bytes=32 time<1ms TTL=128
    Reply from 10.1.28.23: bytes=32 time<1ms TTL=128

    Ping statistics for 10.1.28.23:
        Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
    Approximate round trip times in milli-seconds:
        Minimum = 0ms, Maximum = 1ms, Average = 0ms

    C:\Documents and Settings\Administrator>arp -a

    Interface: 10.1.28.11 --- 0x10003
      Internet Address      Physical Address      Type
      10.1.28.1             00-05-3b-04-2d-48     dynamic
      10.1.28.23            00-14-85-82-16-a5     dynamic

       注意Type是dynamic,就是动态的意思,这样就容易被欺骗.可以用asp -s设置为静态,就能防止ARP欺骗了.

      每台安装有TCP/IP协议的电脑里都有一个ARP缓存表,表里的IP地址与MAC地址是一一对应的,如下表所示。


      主机 IP地址 MAC地址 

      A 192.168.16.1 aa-aa-aa-aa-aa-aa 

      B 192.168.16.2 bb-bb-bb-bb-bb-bb 

      C 192.168.16.3 cc-cc-cc-cc-cc-cc 

      D 192.168.16.4 dd-dd-dd-dd-dd-dd   

      我们以主机A(192.168.16.1)向主机B(192.168.16.2)发送数据为例。当发送数据时,主机A会在自己的ARP缓存表中寻找是否有目标IP地址。如果找到了,也就知道了目标MAC地址,直接把目标MAC地址写入帧里面发送就可以了;如果在ARP缓存表中没有找到相对应的IP地址,主机A就会在网络上发送一个广播,目标MAC地址是“FF.FF.FF.FF.FF.FF”,这表示向同一网段内的所有主机发出这样的询问:“192.168.16.2的MAC地址是什么?”网络上其他主机并不响应ARP询问,只有主机B接收到这个帧时,才向主机A做出这样的回应:“192.168.16.2的MAC地址是bb-bb-bb-bb-bb-bb”。这样,主机A就知道了主机B的MAC地址,它就可以向主机B发送信息了。同时它还更新了自己的ARP缓存表,下次再向主机B发送信息时,直接从ARP缓存表里查找就可以了。ARP缓存表采用了老化机制,在一段时间内如果表中的某一行没有使用,就会被删除,这样可以大大减少ARP缓存表的长度,加快查询速度。 

      从上面可以看出,ARP协议的基础就是信任局域网内所有的人,那么就很容易实现在以太网上的ARP欺骗。对目标A进行欺骗,A去Ping主机C却发送到了DD-DD-DD-DD-DD-DD这个地址上。如果进行欺骗的时候,把C的MAC地址骗为DD-DD-DD-DD-DD-DD,于是A发送到C上的数据包都变成发送给D的了。这不正好是D能够接收到A发送的数据包了么,嗅探成功。 

      A对这个变化一点都没有意识到,但是接下来的事情就让A产生了怀疑。因为A和C连接不上了。D对接收到A发送给C的数据包可没有转交给C。 

      做“man in the middle”,进行ARP重定向。打开D的IP转发功能,A发送过来的数据包,转发给C,好比一个路由器一样。不过,假如D发送ICMP重定向的话就中断了整个计划。 

      D直接进行整个包的修改转发,捕获到A发送给C的数据包,全部进行修改后再转发给C,而C接收到的数据包完全认为是从A发送来的。不过,C发送的数据包又直接传递给A,倘若再次进行对C的ARP欺骗。现在D就完全成为A与C的中间桥梁了,对于A和C之间的通讯就可以了如指掌了。

      【故障现象】 

      当局域网内某台主机运行ARP欺骗的木马程序时,会欺骗局域网内所有主机和路由器,让所有上网的流量必须经过病毒主机。其他用户原来直接通过路由器上网现在转由通过病毒主机上网,切换的时候用户会断一次线。 

    一般ARP欺骗软件运行中,其他被控制电脑就不能上网.

      由于ARP欺骗的木马程序发作的时候会发出大量的数据包导致局域网通讯拥塞以及其自身处理能力的限制,用户会感觉上网速度越来越慢。当ARP欺骗的木马程序停止运行时,用户会恢复从路由器上网,切换过程中用户会再断一次线。  


        解决思路

      1、不要把你的网络安全信任关系建立在IP基础上或MAC基础上,(rarp同样存在欺骗的问题),理想的关系应该建立在IP+MAC基础上。 

      2、设置静态的MAC-->IP对应表,不要让主机刷新你设定好的转换表。 

      3、除非很有必要,否则停止使用ARP,将ARP做为永久条目保存在对应表中。 

      4、使用ARP服务器。通过该服务器查找自己的ARP转换表来响应其他机器的ARP广播。确保这台ARP服务器不被黑。 

      5、使用"proxy"代理IP的传输。 

      6、使用硬件屏蔽主机。设置好你的路由,确保IP地址能到达合法的路径。(静态配置路由ARP条目),注意,使用交换集线器和网桥无法阻止ARP欺骗。 

     
      7、使用防火墙连续监控网络。注意有使用SNMP的情况下,ARP的欺骗有可能导致陷阱包丢失。

    【解决方案】 

      最好的方法是在交换机或者路由器上绑定用户,在用户主机绑定网关MAC.但大型网络工作量较大.一般只在用户那里绑定.
      在PC上绑定路由器或者交换机的IP和MAC地址: 

      1)首先,获得路由器或者交换机的内网的MAC地址(例如C区A栋地址10.1.28.*段的交换机的MAC地址为00-05-3b-04-2d-48)。

    在命令行中输入arp -a,显示

     10.1.28.1             00-05-3b-04-2d-48     dynamic

      2)编写一个批处理文件rarp.bat内容如下: 

      @echo off 

      arp -d 

      arp -s 10.1.28.1  00-05-3b-04-2d-48 

      将文件中的网关IP地址和MAC地址更改为您自己的网关IP地址和MAC地址即可。 

      将这个批处理软件拖到“windows--开始--程序--启动”中。 

      3)如果是网吧,可以利用收费软件服务端程序(pubwin或者万象都可以)发送批处理文件rarp.bat到所有客户机的启动目录。Windows2000的默认启动目录为“C:\Documents and Settings\All Users「开始」菜单程序启动”。 

  • 相关阅读:
    c# 图文添加文字斜水印 优化
    c# 图文添加文字斜水印
    c# bool类型和int类型的互转
    在xcode中新建项目使用Image.xcassets时不显示自定义图片
    修改SearchBar的取消按钮Cancel为中文
    生成新订单号
    java LineNumberReader的使用
    深入浅出多线程——ReentrantLock (二)
    深入浅出多线程——ReentrantLock (一)
    深入浅出多线程——线程基础篇
  • 原文地址:https://www.cnblogs.com/cthulhu/p/1867084.html
Copyright © 2011-2022 走看看