混杂模式

混杂模式

是指一台机器能够接收所有经过它的数据流,而不论其目的地址是否是他。是相对于通常模式而言的,这被网路管理员使用来诊断网路问题,但是也被无认证的想偷听网路通信的人利用。

  • 中文名称
    混杂模式
  • 外文名称
    Promiscuous Mode
  • 用    于
    网路管理员使用来诊断网路问题
  • 相对于
    通常模式

基本简介

混杂模式(Promiscuous Mode)

混杂模式(Promiscuous Mode)是指一台机器能够接收所有经过它的数据流,而不论其目的地址是否是他。是相对于通常模式(又称"非混杂模式")而言的。这被网路管理员使用来诊断网路问题,但是也被无认证的想偷听网路通信(其可能包括密码和其它敏感的信息)的人利用。一个非路由选择节点在混杂模式下一般仅能够在相同的冲突域(对乙太网和无线区域网路)内监控通信到和来自其它节点或环(对令牌环或FDDI),其是为什么网路交换被用于对抗恶意的混杂模式。

混杂模式就是接收所有经过网卡的数据包,包括不是发给本机的包。默认情况下网卡只把发给本机的包(包括广播包)传递给上层程式,其它的包一律丢弃。简单的讲,混杂模式就是指网卡能接受所有通过它的数据流,不管是什么格式,什么地址的。事实上,计算机收到数据包后,由网路层进行判断,确定是递交上层(传输层),还是丢弃,还是递交下层(数据链路层、MAC子层)转发。

通常在需要用到抓包工具,例如ethereal、sniffer、capsa时,需要把网卡置于混杂模式,需要用到软体Winpcap。winpcap是windows平台下一个免费,公共的网路访问系统。开发winpcap这个项目的目的在于为win32应用程式提供访问网路底层的能力。

对于广播式集线器(Hub)来说,假如PC1、PC2、PC3接在同一个Hub上,当PC1给PC3传送包时,Hub将广播这个包,所以PC2实际上也可以看到这个包,但一般情况下它会将这个发给PC3的包丢弃,但如果处于混杂模式,PC2的网卡驱动程式就不会丢弃这个包,而是把这个包送给上层的驱动程式,应用程式。

简单的说,网卡的混杂模式是为网路分析而提供的。

检测混杂模式的基本概念

在网路中,嗅探器接收所有的分组,而不传送任何非法分组。它不会妨碍网路数据的流动,因此很难对其进行检测。不过,处于混杂模式(promiscuous mode)网卡的状态很显然和处于普通模式下不同。在混杂模式下,应该被硬体过滤掉的分组文会进入到系统的核心。是否回应这种分组完全依赖于核心。

网路嗅探的模式分为:混杂模式和非混杂模式

linux下通过C设定混杂模式(以eth0举例)

char *eth_name = "eth0"; //对网卡eth0进行混杂设定

struct ifreq ethreq; //网路接口结构

strncpy(ethreq.ifr_name, eth_name, IFNAMSIZ); //指定网卡名称

if(-1 == ioctl(sock_raw_fd, SIOCGIFFLAGS, ðreq)) //获取网路接口

{

perror("ioctl");

close(sock_raw_fd);

exit(-1);

}

/*此处用 | 是因为必须在保留原来设定的情况下,在标誌位中加入"混杂"方式*/

ethreq.ifr_flags |= IFF_PROMISC;

if(-1 == ioctl(sock_raw_fd, SIOCSIFFLAGS, ðreq)) //将标誌位设定写入

{

perror("ioctl");

close(sock_raw_fd);

exit(-1);

}

相关词条

相关搜索

其它词条