ubnt解决方案
查看: 3924|回复: 8

[分享] linux下防御arp攻击完美策略

[复制链接]

517

回帖

5892

积分

191 小时

在线时间

中校

注册时间
2008-10-30
金币
4477 个
威望
75 个
荣誉
25 个

尚未签到

发表于 2009-5-2 00:51 |显示全部楼层
本帖最后由 yhoqi 于 2009-5-2 00:54 编辑

最近朋友服务器每天经常遭遇arp病毒攻击导致网站无法正常运营,问我有没有好的解决策略,经过google了一番尝试了一下终于得到了解决方案,并找出感染病毒的机器为一台windows机器通知机房,并在本机做好防御策略,问题得到了很好的解决,在这个过程中得到了cuci的热心帮助,在此表示感谢!好了!话不多说具体操作方法如下:
1./*找出ARP攻击的机器*/
获取同一网段下所有机器MAC地址的办法
         
机房有机器中毒,发arp包,通过arpspoof虽然可以解决,也可以找到中毒机器的mac地址,但在机房设备不足的情况下,很难查到mac地址对应的IP。然后我们可以通过一个循环,使用arping来对整个子网下面的机器发一个包,这样就可以在arp下面查看到相应的mac缓存,进而得到对
应的IP地址。

#!/bin/sh
#感谢作者:吴洪声
for ((i = 1; i < 254; i++))      这里应该改为255保险点,看你自己喜欢
do
arping -I eth0 60.191.82.$i -c 1
done
arp -a > mac_table

脚本跑完后,查看当前目录生成的mac_table。
#arp -a 查找你中毒时网关的MAC地址,并记录下来在mac_table里寻找到相对应的机器,仍后就可以找出那台机器感染了ARP病毒。
2./*使用arpspoof抵御ARP攻击*/
#提供方案原创者:yk103,在此表示感谢!
先安装libnet
http://www.packetfactory.net/libnet/dist/libnet.tar.gz
tar -xvzf libnet.tar.gz
cd libnet
./configure
make
make install
安装arpoison
http://www.arpoison.net/arpoison-0.6.tar.gz
tar -xvzf arpoison-0.6.tar.gz
cd arpoison
gcc arpoison.c /usr/lib/libnet.a -o arpoison
mv arpoison /usr/sbin
编写arpDefend.sh脚本.
#!bash
#arpDefend.sh
#yk103
#网关mac地址
GATEWAY_MAC=00:11:BB:A52:40
#目的mac地址
DEST_MAC=ff:ff:ff:ff:ff:ff
#目的ip地址(网段广播地址)
DEST_IP=60.191.82.254

#本地网卡接口
INTERFACE=eth0
#$INTERFACE的mac地址
MY_MAC=00:30:48:33:F0:BA
#$INTERFACE的ip地址
MY_IP=60.191.82.247

#在本机建立静态ip/mac入口 $DEST_IP--$GATEWAY_MAC
arp -s $DEST_IP $GATEWAY_MAC

#发送arp reply ,使$DEST_IP更新$MY_IP的mac地址为$MY_MAC
arpoison -i $INTERFACE -d $DEST_IP -s $MY_IP -t $DEST_MAC -r $MY_MAC 1>/dev/null &


内核一样,只是shell环境可能有些差别,
在ubuntu下应改成这样才能运行
#!/bin/bash
#感谢作者:吴洪声
for ((i = 1; i < 254; i++))
do
arping -I eth0 60.191.82.$i -c 1
done
arp -a > mac_table




Usage: -i device -d dest_IP -s src_IP -t target_MAC -r src_MAC [-a] [-w time between packets] [-n number to send]
示例:arpoison -i eth0 -d 172.16.18.254 -s 172.16.18.19 -t ff:ff:ff:ff:ff:ff -r 00:11:09:E8:78D   



-i eth0 指定发送arp包的网卡接口eth0
-d 172.16.18.254 指定目的ip为172.16.18.254
-s 172.16.18.19  指定源ip为172.16.18.19
-t ff:ff:ff:ff:ff:ff 指定目的mac地址为ff:ff:ff:ff:ff:ff(arp广播地址)
-r 00:11:09:E8:C8:ED  指定源mac地址为00:11:09:E8:C8:ED
上次说到生成了一个MAC_TABLE的一个文件里面存的是ARP表对吧,如果有重复的,怎么快速的把重复的找出来呢,让同事用C做了个小程序,在这里谢谢同事毛毛了!因为这个C是他做的

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char* mac_addr[1000];
read_file(char* filename)
{
//fstream f_dir;
FILE *file_stream = NULL;
file_stream = fopen(filename, "r");
if(file_stream == NULL)
{
printf("can not open file ! \n");
return;
}   
//f_dir.open(filename,   ios::in |ios:ut | ios::app);  
int line_num=0;
int i=0;
int j=0;
while(feof(file_stream) == 0)
  {   
   char * mac = malloc(256);
   //f_dir.getline(charword,256);//读出文件中的一行
   fgets(mac,255,file_stream);
   //printf("line:%s\n",mac);
   mac_addr[line_num]=mac;
   line_num++;   
  }
line_num--;
//printf("line num : %d \n",line_num);
fclose(file_stream);
for(i;i<line_num;i++)
{
for(j=i+1;j<line_num;j++)
{
  char mac_perline_1[18];
  char mac_perline_2[18];
  char * line_1 = mac_addr;
  char * line_2 = mac_addr[j];
  int position = 0;
  int count = 0;
  //printf("line_1:%s\n",line_1);
  //printf("line_2:%s\n",line_2);
  while(line_1[position]!='\n')
  {
   //printf("position:%d\n",position);
   if(line_1[position]==' ')
    {
     count++;
     if(count == 3)
      {
       //printf("befor copy \n");
       memcpy(mac_perline_1,line_1+position+1,17);
       //printf("bbbbb\n");
       mac_perline_1[17]='\0';
              //printf("mac addr1 %s\n",mac_perline_1);
       break;
      }     
    }
   position++;   
  }
  position = 0;
  count = 0;
  while(line_2[position]!='\n')
  {
   if(line_2[position]==' ')
    {
     count++;
     if(count == 3)
      {
       memcpy(mac_perline_2,line_2+position+1,17);
       mac_perline_2[17]='\0';
              //printf("mac addr2 %s\n",mac_perline_2);
       break;
      }     
    }
   position++;   
  }
  if(strcmp(mac_perline_2,mac_perline_1)==0)
   {
    printf("same MAC_ADDR find in line %d and %d \n",i,j);
    printf(" %s %s \n",mac_addr,mac_addr[j]);
   }
}
}
for(i=0;i<line_num+1;i++)
{
  free(mac_addr);
}
  
}
main(int argc, char *argv[])
{
  int err, nargc, i;
  if(argc<2)
   {
     printf("please input the filename\n");                        
     return -1;
   }
         
         
  read_file(argv[1]);
           
  return 0;         
         
         
}




这个是原码,
下面说用法,
在附件里有一个叫file.c的文件,还有一个叫Makefile的文件,还有一个用来测试的mac_table,到时候把file.c 和Makefile放到同一个目录下,执行
make
./mac mac_table
就把重复MAC的那一行ARP表列出来了,能快速的知道那台电脑在发ARP广播,快速的找到中毒的电脑!!!
http://www.kklinux.com/uploads/soft/mac_addr.rar

评分

1

查看全部评分

1768

回帖

8824

积分

245 小时

在线时间

服务区超级版主

女版主

推广先锋灌水天才

注册时间
2009-3-23
金币
6678 个
威望
24 个
荣誉
12 个

尚未签到

发表于 2009-5-2 01:00 |显示全部楼层
虽然看不懂 但是看得出你非常努力~!
回复

使用道具 举报

66

回帖

243

积分

68 小时

在线时间

少尉

注册时间
2009-2-12
金币
169 个
威望
0 个
荣誉
0 个

尚未签到

发表于 2009-5-2 02:27 |显示全部楼层
:hug:
回复

使用道具 举报

7425

回帖

1万

积分

687 小时

在线时间

上校

注册时间
2011-3-20
金币
7493 个
威望
2 个
荣誉
0 个
累计签到:2 天
连续签到:0 天
[LV.20]漫游旅程
发表于 2011-8-19 22:20 |显示全部楼层
技术的进步靠的就是 折腾!
回复

使用道具 举报

188

回帖

4081

积分

96 小时

在线时间

少校

注册时间
2009-3-16
金币
3873 个
威望
0 个
荣誉
0 个

尚未签到

发表于 2011-8-19 22:25 |显示全部楼层
技术的进步靠的就是 折腾
回复

使用道具 举报

7425

回帖

1万

积分

687 小时

在线时间

上校

注册时间
2011-3-20
金币
7493 个
威望
2 个
荣誉
0 个
累计签到:2 天
连续签到:0 天
[LV.20]漫游旅程
发表于 2011-9-4 06:48 |显示全部楼层
bt3 和ubuntu都是linux,道理是一样的。
回复

使用道具 举报

7425

回帖

1万

积分

687 小时

在线时间

上校

注册时间
2011-3-20
金币
7493 个
威望
2 个
荣誉
0 个
累计签到:2 天
连续签到:0 天
[LV.20]漫游旅程
发表于 2011-9-5 08:16 |显示全部楼层
elcomsoft 公司另一个实用工具:ElcomSoft Distributed Password Recovery
回复

使用道具 举报

7425

回帖

1万

积分

687 小时

在线时间

上校

注册时间
2011-3-20
金币
7493 个
威望
2 个
荣誉
0 个
累计签到:2 天
连续签到:0 天
[LV.20]漫游旅程
发表于 2014-2-3 03:42 来自手机 |显示全部楼层
真的是太那个那个
回复

使用道具 举报

7425

回帖

1万

积分

687 小时

在线时间

上校

注册时间
2011-3-20
金币
7493 个
威望
2 个
荣誉
0 个
累计签到:2 天
连续签到:0 天
[LV.20]漫游旅程
发表于 2014-2-5 00:27 来自手机 |显示全部楼层
复制grldr到新建分区,同时建立menu.lst
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册 微信登录

本版积分规则

站点统计 | Archiver | 手机版 | 无线门户 ( 粤ICP备11076993号|粤公网安备44010602008359号 ) |网站地图

GMT+8, 2025-1-19 11:17

返回顶部 返回列表