报错如下:
解决方法一
- 端口并没有问题
- 为什么使用IPPROTO_IP会报权限不够呢?
2、测试成功
解决方法二
1、在网上搜索解决方法是原始套接字中的第三个参数socket.IPPROTO_IP改为socket.IPPROTO_ICMP,虽然不会报错,但是输出不了任何内容
2、查询了第三个参数的含义,在原始套接字中第三个参数(protocol)代表需要接收的包类型,这里是处理包头为icmp的数据包
3、了解到内核在接受到数据包为protocol参数指定的数据包时先交给raw socket处理
4、使用ping命令测试raw是否可以处理icmp包
发现控制台打印了百度的回应信息
源码如下(两种方案都可解决代码问题)
import socket
import threading
import time
activeDegree = dict()
flag = 1
def main():
global activeDegree, flag
HOST = socket.gethostbyname(socket.gethostname()) # 获取IP地址
print(HOST)
# 对于其他系统,要把socket.IPPROTO_IP替换为socket.IPPROTO_ICMP
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_IP)
s.bind((HOST,0)) # 0表示所有端口
s.ioctl(socket.SIO_RCVALL, socket.RCVALL_ON) # 打开混杂模式,接收所有包
print(s.recvfrom(1024))
while flag:
data, addr = s.recvfrom(65565) # 接收一个数据包
host = addr[0]
activeDegree[host] = activeDegree.get(host, 0) + 1
if addr[0] != '10.2.1.8': # 过滤指定IP地址的消息
print(data, addr)
s.ioctl(socket.SIO_RCVALL, socket.RCVALL_OFF) # 关闭混杂模式
s.close()
t = threading.Thread(target=main) # 创建线程
t.start() # 启动线程,开始嗅探
# time.sleep(60) # 主线程等待60秒
flag = 0
t.join() # 等待子线程结束
for item in activeDegree.items():
print(item)