Как определить аппаратный адрес Wi-Fi в Termux

Мне нужно определить MAC-адрес моего устройства (аппаратный), то есть для Wi-Fi. Я использую Termux на устройстве Android, хотя, возможно, ответ будет применим в более общем плане.

Я использую python, но подойдет и любой bash.

На некоторых устройствах 2017 года работало следующее:

import subprocess
result = subprocess.run(['ip','link'], stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
rc,so, se = result.returncode, result.stdout, result.stderr
assert not rc
ipl = re.split('\n[^ ]+ ', so, re.MULTILINE)
wlanl = [L for L in ipl if L.startswith('wlan0')]
assert wlanl
HWadd = re.findall('link/ether (.*?) ',wlanl[0])[0].lower()

однако это странно не работает (я не могу заставить re.split работать так, как я ожидал) на новом устройстве 2019 года.

Вместо этого теперь у меня есть почти такая же неуклюжая альтернатива, которая работает:

import subprocess
result = subprocess.run(['ip','link'], stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
rc,so, se = result.returncode, result.stdout, result.stderr
assert not rc
ipl =  re.findall('\n[0-9]+: wlan0:.*?\n +link/ether ([^\n]*?) .*?\n', so, re.MULTILINE+ re.DOTALL) 
assert ipl
HWadd = ipl[0].lower()

Есть ли где-нибудь более надежный способ извлечь эту информацию из ОС?

Кстати, используя termux-wifi-connectioninfo дает:

"mac_address": "02:00:00:00:00:00"

1 ответ

Я не пробовал ваш пример Python, но то, что вы делаете, работает в bash:

~ $ ip link | grep -A1 wlan0
25: wlan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DORMANT group default qlen 3000
    link/ether aa:bb:cc:11:22:33 brd ff:ff:ff:ff:ff:ff

Существует также запрос функции на добавление дополнительных утилит, которые могли бы сделать это с помощьюifdata -ph wlan0 если он добавлен.

Другие вопросы по тегам