基本简介
混杂模式(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);
}














