Как определить аппаратный адрес 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
если он добавлен.