Python获取本机网卡的MAC地址、IP地址和路由表

2023-10-13 19:29:25 浏览数 (2)

一、获取Mac地址

1、单个网卡

代码语言:javascript复制
>>> import uuid
>>> address = hex(uuid.getnode())[2:]
>>> '-'.join(address[i:i 2] for i in range(0, len(address), 2))
'f0-03-8c-09-8c-34'

2、获取多网卡MAC地址

使用pip安装Python扩展库psutil,运行以下的代码:

代码语言:javascript复制
from psutil import net_if_addrs

for k, v in net_if_addrs().items():
    for item in v:
        address = item[1]
        if '-' in address and len(address)==17:
            print(address)
二、获取本机IP地址

1、windows下: Python标准库socket中有可以获取本机IPV4地址的方法,下面是网上非常常见的一种用法:

代码语言:javascript复制
>>> import socket
>>> hostname = socket.gethostname()
>>> hostname
'DESKTOP-I734J3O'
>>> socket.gethostbyname(hostname)
'192.168.0.103'

2、Mac下:上面的代码在Windows下运行良好,但是无意中发现在Mac系统下运行不正常,返回的是本机回环地址127.0.0.1,而不是真正的IP地址。经过查阅大量资料,终于发现socket模块中另一个函数的妙用,那就是getaddrinfo()函数,该函数用法为getaddrinfo(host, port, family=0, type=0, proto=0, flags=0),返回值是一个五元组的列表,该五元组形式为(family, type, proto, canonname, sockaddr),其中最后一个元素sockaddr对于IPV4协议是(IP address, port)形式的元组,而对于IPV6协议是(address, port, flow info, scope id)形式的元组,也就是说,不管是IPV4还是IPV6,上面的函数都可以正确地获取IP地址。 于是,继续上面的代码:

代码语言:javascript复制
>>> addrs = socket.getaddrinfo(hostname,None)
>>> for item in addrs:
     print(item)
 
(, 0, 0, '', ('fe80::b976:b065:27d:3747', 0, 0, 10))
(, 0, 0, '', ('fe80::1456:951:2418:27cf%7', 0, 0, 7))
(, 0, 0, '', ('192.168.0.103', 0))
(, 0, 0, '', ('2001:0:9d38:6ab8:1456:951:2418:27cf', 0, 0, 0))

如此便可以获取本机所有IPV4和IPV6地址,如果只想获取IPV4地址,再继续执行下面的代码:

代码语言:javascript复制
>>> [item[4][0] for item in addrs if ':' not in item[4][0]][0]
'192.168.0.103'
三、路由表

方法:采用ARP协议获取局域网内所有计算机的IP地址与MAC地址,思路是使用系统命令arp获取ARP表并生成文本文件,然后从文件中读取和解析信息。

代码语言:javascript复制
import os
from socket import gethostbyname, gethostname

 获取本机IP地址

代码语言:javascript复制
host = gethostbyname(gethostname())

获取ARP表

代码语言:javascript复制
os.system('arp -a > temp.txt')

with open('temp.txt') as fp:
    for line in fp:
        line = line.split()[:2]
        if line and
           line[0].startswith(host[:4]) and
           (not line[0].endswith('255')):
            print(':'.join(line))

0 人点赞